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PRÉFACE 
LE | 

Ce livre tout entier part d’une constatation très simple, mais importante : 
le monde dans lequel nous vivons a trois dimensions, mais l’écran d’un 
ordinateur, tout comme une feuille de papier, n’en a que deux. D’où un 
évident problème, dès qu'il s’agit de représenter sur cet écran un objet 
tridimensionnel. 

Et pourtant, cela n’est pas aussi difficile qu’on se l’imagine fré- 
quemment. Des effets souvent superbes (voyez les figures de ce livre) 
peuvent être obtenus à partir de programmes qui ne dépassent pas une 
centaine de lignes, au grand maximum. C’est pourquoi l’on peut regretter 
que d'innombrables jeux, sur l’ Amstrad comme sur les autres appareils, 
n’utilisent pas, ou mal, le graphisme en trois dimensions, là où ce serait 
parfois nettement plus esthétique. Seulement voilà, pour arriver à faire du 
graphisme en trois dimensions, il faut connaître un peu de mathématiques, 
et surtout beaucoup d’astuces ! 

C’est cette connaissance que cet ouvrage a la prétention de donner à 
toutes et à tous. Que vous soyez mathématicien, ou que vous ignoriez ce 
qu'est une racine cubique, peu importe. Le Chapitre II est là pour vous 
aider. Et pas seulement lui; outre les dix-huit programmes de ce livre, 
quelque 45 schémas explicatifs assistent le texte pour vous en donner une 
compréhension optimale. Ces schémas ont été réalisés à la main: je vous 
prie donc d’avance de me pardonner d'éventuelles imperfections. Outre 
ces schémas, vous trouverez aussi dix-huit illustrations obtenues sur 
imprimante Amstrad (type DMP-1) grâce à un programme spécial. Au 
total, cela fait trente pages de figures environ. Ces figures sont numérotées 
en fonction des chapitres auxquels elles se rapportent, avec une lettre 
caractéristique (par exemple I.A., VII.C, etc.). 

De même les programmes, tous en BASIC et aussi simples que possible, 
sont numérotés avec un chiffre arabe derrière le nombre romain de leur 
chapitre de rattachement: VI.3, VIL2, etc. 


Je tiens à préciser immédiatement les points suivants : 

e Primo, ces programmes ont tous été réalisés sur un Amstrad CPC 464. 
Bien évidemment, cela n'empêche pas les possesseurs d’autres 
machines, et plus particulièrement de matériel Amstrad, de les utiliser à 
leur profit. Ils sont tous compatibles avec les autres CPC. Pour les autres 
matériels, une transcription sera éventuellement nécessaire (voir le 
Chapitre I à ce sujet). 
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e Secundo, ils ont tous été longuement testés. S’ils ne marchent pas bien, 
vérifiez que vous les avez correctement entrés : une toute petite erreur 
peut suffire à les stopper complètement, chacun le sait. 


e Tertio, j'ai jugé essentielle, avant toute chose, leur simplicité. Ils ne sont 
donc pas optimaux. D’ailleurs, je serai ravi de recevoir toute suggestion 
me permettant de les simplifier encore. 


e Enfin, et surtout, ces programmes ne sont pas des buts en eux-mêmes : 
ils sont essentiellement destinés à être rajoutés à des programmes 
personnels, que ce soit de jeux ou semi-professionnels. Et ils ont surtout 
valeur d'exemple. Le but de cet ouvrage n’est pas en effet de vous 
enfermer dans le cadre rigoureux de programmes tout faits, mais bien au 
contraire de vous permettre de réaliser vous-même les programmes qui 
seront exactement adaptés à vos exigences. Il n’y a pas de limite à 
l’imagination, surtout quand elle peut courir sur trois dimensions ! 
Avant de vous laisser à votre lecture, je dois préciser quelques points. 

Tout d’abord, certains programmes, les plus longs, ou les plus difficiles, 
sont doublés d’un organigramme qui permettra au programmeur qui les 
connaît un peu de mieux s’y retrouver. Toutefois, pour des raisons de 
simplicité, les conventions de ces organigrammes ne sont pas strictement 
semblables à celles en usage, et de nombreuses expressions s’y trouvent 
abrégées. La liste de ces conventions et de ces abréviations figure en fin de 
préface. 

D'autre part, pour que vous puissiez vous-même vérifier que vous avez 
bien compris certains points délicats et importants, certains chapitres sont 
dotés de questions dans le texte. La réponse à ces questions se trouve 
séparée en fin de chapitre. Est-il besoin de dire que je vous recommande 
d'essayer d’y répondre, quand vous les rencontrez dans le texte, sans vous 
précipiter vers la solution ? Si vous trouvez la solution facilement, bravo, 
sinon vérifiez que vous avez bien tout compris dans le paragraphe qui 
précède la question. 

Enfin, j'ai jugé plus commode que les figures, programmes et 
organigrammes précèdent leurs commentaires dans l’ouvrage. De même, 
certains mots en italique, qui sont nouveaux, sont immédiatement suivis de 
leur définition. De même encore, chaque chapitre est précédé d’une courte 
introduction qui résume son contenu ; et le plan général de l’ouvrage est 
esquissé au Paragraphe 5 du Chapitre I. 

L'ensemble se compose de onze chapitres, et de deux annexes pour ceux 
qui ont tout compris dans le Chapitre II. Alors il ne me reste plus... qu’à 
vous laisser les lire ! 
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INTRODUCTION 


Ce court chapitre est destiné à récapituler les possibilités des diverses machines 
de la firme Amstrad et, par la même occasion, à faire le lien avec les autres 
machines. En effet, même si vous n’avez pas d’Amstrad, ce livre pourra vous être 
profitable, pour peu que vous connaissiez assez bien le BASIC de votre appareil 
pour pouvoir transcrire les programmes qui sont listés dans la suite. 

Nous examinerons ensemble comment une telle transcription est possible, en 
regardant de plus près les éléments graphiques et mathématiques de l’ Amstrad : à 
vous alors de faire (éventuellement) le tableau de correspondance des BASIC. 

Enfin, nous esquisserons le plan global de cet ouvrage. Des figures, qui 
parsèment ce chapitre, vous permettront de mieux juger de ce qu’il est possible de 
faire avec un peu de réflexion et pas mal de travail informatique... ou avec le 
présent ouvrage en main. 


1._LES ELEMENTS GRAPHIQUES DES AMSTRAD 





Rappelons que les Amstrad (CPC 464, 664, 6128) ont, pour leur prix, 
une très bonne résolution: en mode 2 (haute résolution), 640 x 200 
points, en mode 1 (moyen), 320 x 200, et en mode 0 (coloré), 
320 X 100 points. Le nombre de couleurs évolue dans le sens inverse : 
deux, quatre ou seize suivant le mode, couleur du fond comprise. 

Cet ouvrage traitant de questions graphiques assez fines, nous 
n’utiliserons jamais le mode 0. 

Les Amstrad possèdent un jeu d’instructions graphiques très performant 
et de plus en plus, au fur et à mesure que l’on s’élève dans la gamme. Je 
rappelle que, pour que les programmes soient compatibles sur tous, seules 
les instructions du CPC 464 sont utilisées. 

Comme tous les ordinateurs, l’ Amstrad possède un curseur graphique de 
la taille d’un point. Ce curseur peut être déplacé sans être rendu visible 
avec l'instruction MOVE x, y, qui place le curseur à la position (x, y). 
L'instruction PLOT x,y,i rend le curseur visible en (x,y), dans la 
eme couleur. L’instruction DRAW x, y,i trace un trait de l’ancienne 
position du curseur jusqu’à (x,y), dans l’encre i aussi. Toutes ces 
instructions sont doublées de leurs équivalentes relatives (MOVER, 
PLOTR, DRAWR), où (x, y) signifie: en se déplaçant de x horizonta- 
lement, et de y verticalement. 

Les coordonnées absolues (x,y) sont mesurées par rapport à une 
origine, qui au début se trouve en bas à gauche sur l’écran, x étant compté 
positif vers la droite, et y vers le haut. L’origine peut être déplacée 
n'importe où sur ou hors de l’écran, grâce à l’instruction ORIGIN a, b, qui 
la place au point (a, b). Dans tous les cas, x et y peuvent varier de — 32760 
à 32760. Mais ils ne seront pas nécessairement sur l’écran. En effet, quel 
que soit le mode, l’écran est contenu dans le rectangle où x est compris 
entre 0 et 639, et y entre 0 et 399 (quand l’origine est placée en (0,0), bien 
entendu). 


2. ELEMENTS MATHEMATIQUES DES AMSTRAD 





De ce point de vue, les trois Amstrad ne diffèrent pratiquement pas. 
L’Amstrad possède cinq opérateurs (+, —, *,/, Ÿ ), sept fonctions pures 
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Figure I.A: Vaisseau spatial obtenu à l’aide du programme “Tous polyèdres” 
(Chapitre VI). Vue de face, vue de dessus (demie), vue latérale (toutes sans parties 
cachées). 


AGE 


(SIN, COS, TAN, ATN, EXP, LOG, LOG10) et deux autres 
(ABS, SGN), en plus de la racine carrée (SQR). En cela, il ne diffère 
guère des autres ordinateurs et machines à calculer, sauf de celles qui n’ont 
malencontreusement pas d’arc tangente (ATN). 

Les fonctions trigonométriques notamment nous seront extrêmement 
utiles tout au long de ce livre (nous y reviendrons au chapitre suivant). 
Elles permettent déjà de suppléer à l'absence d'instruction circle 
permettant de faire des cercles (voir manuels à ce sujet). 

Les Amstrad peuvent calculer sur des entiers (distingués par un signe % 
à la fin de leur nom, ou définis à l’avance comme entiers par l’instruction 
DEFINT) ou sur des réels (pas de distinction en général). 

On peut y dimensionner des matrices par l'instruction DIM: DIM a 
(5, 6) dimensionne la matrice a à 5 lignes et 6 colonnes. C’est un ordre que 
nous utiliserons presque à chaque programme, car il est essentiel de 
pouvoir stocker des données quelque part. Certaines matrices serviront de 
pile, c’est-à-dire qu’on y empilera les données au fur et à mesure qu’elles 
viendront, et on les reprendra ensuite, comme on fait d’une pile d’assiettes 
qu’on place dans un placard. On peut aussi dimensionner des matrices 
d’entiers (en mettant un % derrière le nom, là aussi). 

En principe, comme c’est normal, le calcul sur les entiers est plus rapide. 
Je n’ai toutefois pu mettre dans tous les programmes les DEFINT ou les % 
qui auraient été utiles. Je pense que le lecteur pourra le faire sans 
problème, le texte précisant ce qui est entier et ce qui ne l’est pas. 

D'autre part, vous serez peut-être surpris de constater que dans tous ces 
programmes, l’ordre DEF EN, qui permet de définir une fonction, n’est 
jamais utilisé. De fait, je pense (sans en être certain, j’en conviens) que cet 
ordre ralentit les programmes, alors qu’il est pratiquement aussi simple de 
faire un GOSUB vers une routine qui calcule la valeur de la fonction. 


3. AUTRES INSTRUCTIONS 





Nous aurons à utiliser bien des fois l’ordre INKEY qui permet de tester 
si une touche du clavier est pressée, et si elle l’est en même temps que 
CTRL ou SHIFT (ou les deux). L'ordre INKEY$ est un peu différent : à 
tout moment, INKEY$ est égal au caractère tapé au clavier (s’il y en a un). 
Nous utiliserons souvent les deux lignes suivantes : 


=. 16:< 


10 a$=INKEYS:IF a$="” GOTO 10 
qui fait attendre la machine jusqu’à ce qu’une touche soit pressée, et: 
WHILE INKEY(n)=—1 :WEND 


qui place la machine dans une boucle conditionnelle WHILE-WEND tant 
que INKEY (n) = —1, c’est-à-dire tant que la touche n° n n’est pas 
pressée. 

Nous utiliserons bien sûr constamment les ordres PRINT, INPUT, 
FOR... NEXT, GOTO, GOSUB, IF... THEN... ELSE, etc., qui 
n’appellent aucun commentaire, sauf pour PRINT. Rappelons que cet 
ordre peut être remplacé par un point d'interrogation (? a = PRINT a), et 
que l'instruction PRINT CHRS (n) écrit le n°°"° caractère de la table des 
caractères. Les caractères usuels du clavier ont des numéros compris entre 
32 et 122. Le caractère 13 est équivalent d’une pression de la touche 
ENTER. Le caractère 7 est un bip sonore. Dans tous les cas, le caractère 
peut être placé n'importe où sur l’écran par l'instruction LOCATE x, y, 
qui place le curseur de texte à la colonne x de texte, et à la ligne y (y est 
compris entre 1 et 25, et x entre 1 et 80 en mode 2, et 40 en mode 1). En 
outre, après l’exécution d’un ordre TAG, le curseur de texte se trouve au 
même endroit que le curseur graphique, ce qui permet de tracer un 
caractère vraiment n'importe où sur l'écran. Cet assujettissement est 
interrompu par l’ordre TAGOFF. 


4._INSTRUCTIONS SUPPLEMENTAIRES DES CPC 664 ET 6128 


Si vous possédez l’une de ces deux machines, vous pourrez facilement 
apporter quelques petites corrections aux programmes. En effet, ces 
appareils possèdent une douzaine d’ordres graphiques supplémentaires ou 
améliorés, ce qui vous permettra certainement des variations intéressantes. 

En outre, un des ordres de texte supplémentaires, dont l’absence est 
assez gênante sur le 464, vous sera bien utile ; c’est l’ordre CLEAR INPUT 
qui vide la mémoire clavier. En effet, le BASIC mémorise les touches 
pressées durant l’exécution d’un programme, pendant un certain temps et 
jusqu’à concurrence de vingt. Dès lors, si vous appuyez sur les touches du 


47 


clavier ou sur la manette durant l’exécution, et c’est obligatoire pour de 
nombreux programmes, vous verrez au prochain INPUT, ou à la prochaine 
interruption, réapparaître tous ces caractères dont nul n’a que faire. Les 
heureux possesseurs des 664 et 6128 sauront donc, j'en suis persuadé, 
profiter de cette instruction que les propriétaires de 464 n’ont malheureu- 
sement pas. 


5. COUP D'ŒIL EN AVANT 








Qu’allons-nous voir à présent ? Je vais ici résumer très brièvement le 
contenu des autres chapitres. 

Le Chapitre II est consacré à des notions de mathématiques élémen- 
taires mais importantes : il vaut donc mieux le lire. Le Chapitre III est sans 
intérêt réel, mais il nous permettra de rentrer sans trop de “casse” dans 
l'univers tridimensionnel, d’abord toujours difficile. Le Chapitre IV nous 
permettra de nous reposer de cette courte aventure pour l’étude d’un petit 
truc du plan qui nous sera bien utile. Mais, au Chapitre V, le vif du sujet 
sera abordé, et l’ensemble deviendra vraiment très sérieux avec le 
Chapitre VI, consacré aux polyèdres, et qui est le plus long de tous. Le 
Chapitre VII vous grisera de l’air des sommets scientifiques : des questions 
vraiment complexes y seront abordées, et partiellement résolues. 

Après un tel effort, le Chapitre VIII sera bien reposant, car il expose des 
principes très simples (qui sont d’ailleurs applicables à n’importe quoi). Le 
Chapitre IX réabordera une question importante (les surfaces), mais d’un 
point de vue tout à fait différent. Le Chapitre X vous ouvrira des 
perspectives nouvelles mais seulement superficiellement et de loin, car le 
reste est, je pense, déjà bien assez complexe, sans qu’on se mêle d’y 
apporter des détails qui sont tout de même, dans l’ensemble, assez raffinés. 
Le Chapitre XI constitue la conclusion de l’ensemble, comme le présent 
chapitre en est l’introduction. 

Et maintenant que les présentations sont faites, il ne me reste plus qu’à 
vous souhaiter une bonne lecture. 
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Il 
RAPPELS DE GEOMETRIE 
ET DE MATHEMATIQUES 








Que vous soyez agrégé de mathématiques ou que vous n’ayez jamais entendu 
parler de sinus, vous pouvez faire du graphisme en trois dimensions. Mais un 
minimum de maths, et plus spécialement de géométrie, est absolument nécessaire. 
Il ne s’agit pas de notions difficiles, au contraire. Il ne faut donc pas craindre de les 
aborder : cela vous permettra de comprendre la suite. Evidemment, si vous refusez 
absolument d’approcher, même de loin, un univers qui vous semble hostile, vous 
pouvez toujours passer au chapitre suivant et appliquer directement les formules, 
sans chercher à les comprendre, mais ce serait dommage, d’autant plus que vous 
risquez de ne pas pouvoir adapter certains de ces programmes à vos propres 
besoins, ce qui est le but principal de cet ouvrage. 

Donc, il vaut mieux que vous vous y plongiez, même avec effort : on n’a rien sans 
rien, n'est-ce pas ? Naturellement, rien ne vous empêche de décrocher en cours de 
route, certaines notions n'étant pas absolument nécessaires. 

Si, par contre, vous êtes déjà très fort en sciences, ce chapitre peut 
(éventuellement) servir à vous rafraîchir un peu la mémoire, ou simplement à 
préciser mes notations. Mais il est fait pour des personnes qui ne savent 
pratiquement rien en géométrie: certains points vous paraîtront alors peut-être 
trop détaillés. Je m’en excuse d’avance, mais il faut bien satisfaire tout le monde. 

A présent, si vous savez seulement ce que c’est qu’un point, une droite et un 
plan, laissez-vous mener ; dans quelques pages, vous saurez le reste. 


1. LES COORDONNEES DE L'ESPACE ET DU PLAN 


On a souvent besoin de préciser sa position. Il existe pour cela plusieurs 
moyens. Par exemple, indiquer le numéro d’une borne kilométrique, sur 
une route ; ou sa latitude et sa longitude ; etc. 

Vous pouvez avoir besoin de vous repérer sur une droite ou une courbe, 
sur un plan ou une surface, dans l’espace en général. 

Sur une droite c’est très facile, il suffit de choisir un point arbitraire sur la 
droite (le centre d’une grande ville, pour une route par exemple), et de 
donner votre distance à ce point, que nous appellerons origine, ou O: c’est 
ce que fait la borne kilométrique. 

Sur un plan, le sol, ou votre plancher par exemple, c’est un peu plus 
subtil. Un moyen simple consiste à donner, sur le plancher, la distance du 
point où vous vous trouvez par rapport à deux des murs. L’intersection de 
ces murs sera l’origine. Les murs en eux-mêmes coupent le plancher selon 
des droites. Ces droites, nous les appellerons axes. 
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Cartésiennes Polaires 





Figure II.A.a 
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Figure II.A.b 


_ 23 - 


Vu d’en haut, votre plancher sera donc à peu près semblable à ce que 
montre le schéma à gauche de la Figure IL.A.a (p. 22): vous reconnaissez 
l’origine O et les deux axes que nous appellerons Ox et Oy. Remarquez 
que ces deux axes sont ainsi nommés parce qu’en plus d’être des droites, ils 
sont dotés de petites flèches à l’une de leurs extrémités ; ce sont des droites 
orientées. 

A présent, comment repérer le point M, placé quelque part sur ce plan ? 
C’est tout simple. M a deux projections m, et m, respectivement sur Ox et 
Oy, obtenues en abaïssant des perpendiculaires (voir Figure II.A.a). Si l’on 
appelle x la distance de O à m,, et y la distance de O à m,, le couple (x, y) 
s’appelle coordonnées cartésiennes du point M. Tout point a ainsi deux 
coordonnées cartésiennes dans un plan, et inversement, si l’on se donne deux 
nombres, on peut trouver le point dont ils sont les coordonnées. 

Remarquez une chose importante: ces deux nombrex x et y ont un 
signe. Ce signe est plus (positif) si la flèche joignant O au point m concerné 
est dans le même sens que l’axe (comme pour y), et négatif sinon. Ainsi, 
dans le cas de figure, x est négatif, car la flèche joignant O à m, est dirigée 
dans le sens contraire de l’axe Ox. Cette distinction est importante, sans 
quoi il y aurait quatre points dans le plan pour chaque couple de 
coordonnées, et ce ne serait pas commode ! 

Les coordonnées polaires sont un autre moyen de repérer un point dans 
le plan. Elles utilisent les angles. Chacun sait, je pense, ce qu’est un angle. 
Nous verrons tout à l'heure comment le mesurer. Je prendrai l’habitude, 
pour distinguer les angles des distances comme x et y, d'utiliser pour les 
désigner des lettres grecques (!), ou de mettre un accent circonflexe dessus 
comme ceci : à. Les coordonnées polaires, c’est une distance, notée r, et un 
angle 0. La première est la distance du point M à l’origine O: c’est ce que 
mesurent les joueurs de boule, en cas de litige. L’angle 8 est l’angle 
séparant Ox de OM, avec son signe que nous verrons au paragraphe 
suivant. Tout cela est visible sur la Figure II.A.a, à droite. 

Et pour l’espace ? Là, trois moyens sont possibles (il en existe d’autres 
encore, je donne les principaux). 

Et tout d’abord les coordonnées cartésiennes, encore elles. Mais cette 
fois, il y en a trois: x, y, z. Regardez la figure II.A.b. Du point M à 
repérer, on abaisse une verticale (parallèle à Oz), et l’on obtient un 
point m dans le plan qui contient les deux axes Ox et Oy, plan que nous 
appellerons désormais xOy. Ce point m a, dans ce plan, deux coordonnées 


(1) En particulier @ (thêta), y (psi), œ.(phi), « (alpha). 
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cartésiennes x et y, comme nous l’avons vu. En ajoutant donc à ce plan un 
troisième axe Oz qui lui est perpendiculaire, et en mesurant la distance 
entre m et M (positive si la flèche est dans le même sens que Oz, négative 
sinon), on obtient la valeur de la troisième coordonnée z. Voilà quelles 
sont les trois coordonnées cartésiennes (x, y, z) d’un point. Retenez-les 
bien, car ce sera surtout ce système qui sera utilisé dans la suite, les deux 
autres ne servant que dans certains cas. 


s 


Avant de passer aux sphériques, il existe un système mixte, dit à 
coordonnées cylindriques. Dans ce système, on repère m par ses 
coordonnées polaires dans le plan, r et @ (g au lieu de @ pour éviter la 
confusion avec les sphériques). La signification de z reste inchangée. 

Les sphériques sont l’homologue des polaires du plan. Mais ici, outre r 
qui est la distance de M à O encore, il y a deux angles. L’angle 8 est l’angle 
séparant l’axe Oz de OM. L’angle y est l’angle séparant l’axe Ox de Om. 
L'’axe Oy, ici, ne sert à rien, tout comme pour les cylindriques et les 
polaires. 

Tout cela vous paraît peut-être très artificiel. C’est un tort. Un pilote 
d'avion, en indiquant son altitude et le point à la verticale duquel il se 
trouve, ne fait jamais que donner sa coordonnée z et le point m (qui peut 
être repéré en cartésiennes, mais aussi en cylindriques, par exemple : “Je 
suis à 300 pieds à la verticale du point situé à vingt kilomètres au sud-est de 
l'aéroport.” En effet, sud-est équivaut à + 45 degrés par rapport au sud). 
Le marin, lui, utilise les sphériques sans le savoir. Lorsqu'il précise sa 
latitude et sa longitude, il ne fait jamais que donner des angles qui sont des 
coordonnées sphériques ; cela est d’ailleurs très logique, car la Terre, et 
par conséquent la surface océane, est sphérique (enfin, à peu près). 
Évidemment r n’est pas alors précisé, car c’est une constante : la distance 
au centre de la planète, c’est-à-dire son rayon ; inutile de parler d’une 
chose qui ne change pas. 

Vous voyez donc que tous les systèmes de coordonnées peuvent servir. 
Cependant les cartésiennes restent sans conteste les plus commodes, et 
nous les utiliserons presque toujours. 

Je voudrais placer ici une remarque que vous avez peut-être déjà faite. 
Pour une droite il faut, pour se repérer, une coordonnée. Sur un plan, ilen 
faut deux. Dans l’espace, il en faut trois. Ce nombre de coordonnées 
nécessaires pour se repérer dans un domaine donné est appelé dimension 
du domaine. Nous dirons ainsi que la droite est un domaine à une 
dimension, que le plan est bidimensionnel, et que l’espace (usuel) est, 
devinez... à trois dimensions. 
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Nous verrons au Chapitre IX que toutes les surfaces, et pas seulement 
les plans, sont bidimensionnelles. On s’y repère à l’aide de deux 
coordonnées appelées paramètres. Nous l’avons déjà vu : sur une sphère 
(la Terre, au niveau des eaux), on se repère à l’aide de deux paramètres, la 
latitude et la longitude, qui ne sont d’ailleurs que les deux dernières 
coordonnées sphériques. Vous voyez ainsi que certaines coordonnées sont 
surtout adaptées à certaines surfaces, ou à certaines courbes. On ne les 
choisit donc pas au hasard. 

Cette dissertation philosophique sur la dimension étant achevée, je vais 
à présent donner, pour éviter de fâcheux mélanges, les formules qui 
permettent de passer d’un système à l’autre, car cela sert fréquemment. Si 
vous ne connaissez rien des sinus et consinus, passez directement au 
paragraphe suivant, puis revenez ici. Dans ces formules, comme dans 
toutes les autres, le point ( : ) signifie multiplié par, cos est le cosinus, sin 
le sinus, etc., r° signifie r au carré (c’est-à-dire r : r), sqr (r) la racine der, 
et x le nombre pi. 


FORMULES DE 
CHANGEMENT DE COORDONNÉES 


PLAN 


des cartésiennes aux polaires : 

r=sqr(x?+y?); 0=atn e) + (1 — sen (x)) : 5 O 
des polaires aux cartésiennes : 

x=r:cos(8); y=r:sin(6) 


ESPACE 


des cartésiennes aux cylindriques, des cylindriques aux cartésiennes : 
comme dans le plan, en remplaçant @ par y, et avec z=z. 


des cartésiennes aux sphériques : 


2 2 
r = sqr (x? + y? + 22); 6=an (TE) 


96 


y = atn F) +(1—sgn(x)) . O 
des sphériques aux cartésiennes : 

x=r:sin(@):cos(y) y=r:sin(8) :sin(y) z=r:cos(8) 
des sphériques aux cylindriques : 

r=r:sin(0); z=r:cos(8); œ=Y 


(Le premier r est celui des cylindriques, les deux autres sont des 
sphériques.) 


des cylindriques aux sphériques : 


r=sqr(r” +2); 6=atn () ; Y=p (Remarque inverse.) 


(*) Sauf si x = 0; dans ce cas, l'angle vaut sen (y) + 


2. ELEMENTS DE TRIGONOMETRIE 





Je dois avouer que j'ai toujours été surpris de voir l’effroi que suscite 
fréquemment chez les gens le mot de trigonométrie, comme si elle était le 
fondement même des mathématiques qui, hélas, demeurent de nos jours, 
malgré les efforts des enseignants, pour la plupart de nos concitoyens 
totalement absconses. 

Je me fais fort de prouver en deux pages que la trigonométrie ne mérite 
pas cette terrible réputation, du moins dans ses fondements. 

Tout part des angles. Tout le monde sait, intuitivement, en fait, ce qu’est 
un angle. Vous savez peut-être aussi qu’il existe en France deux moyens 
concurrents de les mesurer. De ces deux moyens, qui sont disponibles sur 
l’Amstrad, l’un est totalement artificiel, mais remonte à la nuit des temps ; 
le second est plus naturel, mais plus récent et pas du tout “dans les 
mœurs”. 
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Vous avez certainement reconnu les degrés et les radians. Pour les 
premiers, on décide (arbitrairement) que le plus grand angle possible, 
c’est-à-dire le tour entier sur soi-même, fait 360°. Le reste en résulte. 
L'angle que vous faites avec votre ancienne position en tournant sur 
vous-même d’un quart de tour par exemple (angle droit), fait 360/4 soit 
90°. Cela, presque tout le monde le sait. 
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Figure II.B, schémas a, b, c. 
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Figure II.B, schéma d. 


Le second moyen de mesure, en radians, est expliqué par le schéma a de 
la Figure ILB (les lettres qui distinguent les schémas sont blanches, et 
entourées d’ellipses ou de cercles). Regardez bien le cercle de centre O qui 
y figure. A sa droite, on a mis, tout contre, un axe AZ, A étant le point de 
contact. A présent, sur cet axe, prenons un point M donné, de 
coordonnée Z (rappelez-vous: une seule coordonnée sur une droite). 
Imaginez ensuite que l’on remplace le segment AM par un bout de ficelle. 
Puis on enroule ce bout de ficelle (dont la longueur est Z) autour du cercle, 
comme autour d’un yoyo, après l’avoir attaché en A. L’autre bout finit par 
arriver sur le cercle en M’. Eh bien, l’angle séparant l’axe Ox (ou OA, si 
vous préférez) de OM’ mesure exactement Z radians. Voilà, c’est tout 
simple, en fait. 

Précisons simplement deux choses. D’abord, cela ne doit pas dépendre 
de l’unité de mesure prise sur l’axe, ni du rayon du cercle. On décide donc 
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que ce rayon vaut 1 (en mathématiques, on n’exprime pas les longueurs en 
mètres ou centimètres mais en unités, ce qui peut représenter n'importe 
quoi puisque cela ne représente rien, justement). La distance OA vaut 
donc 1. D'autre part, l’axe AZ est orienté (vers le haut). Ainsi, la 
coordonnée de P, qui est en dessous de A, est — Z négative). L’angle 
AOP' est donc également négatif. Comment le voit-on? C'est assez 
simple. L’angle AOM' est dans le sens dit trigonométrique, c’est-à-dire 
dans le sens inverse des aiguilles d’une montre : il est donc positif. L'autre 
est dans le sens inverse (voyez la flèche) : il est donc négatif. 

Remarquons enfin et surtout, primo, que le tour d’un cercle de rayon 1 
vaut 27 (dites deux pi; la lettre x représente le nombre 3,141 592...). 
Donc, 2x radians = 360°. 

Secundo, une remarque qui vaut pour les deux systèmes de mesure: si 
vous tournez sur vous-même de, par exemple, 30°, puis que vous faites un 
tour complet (360°), vous aurez tourné de 390°. Mais le tour complet ou 
rien, c’est la même chose : il ne change pas votre position. Donc entre un 
angle de 390° et un angle de 30°, il n’y a pas de différence. D’une façon 
générale, vous pouvez ajouter ou retrancher 360° (ou 2x rad) autant de 
fois que vous le voulez à un angjle, il restera le même. Dans la suite, nous 
prendrons des angles compris entre — 180° (— x rad) et + 180° (x rad), ce 
qui représente tous les angles possibles. 

A partir de ces angles, nous pouvons trouver leur sinus, leur cosinus et 
leur tangente assez facilement. 

Regardez attentivement le schéma b de la Figure II.B. On y voit de 
nouveau O, AZ, et le cercle de rayon 1, qui porte le nom de cercle 
trigonométrique. Un point P se trouve sur ce cercle, et on appelle « l’angle 
qui sépare OA de OP. Or, voyez que le point P peut être projeté sur les 
deux axes Ox et Oy, respectivement en I et J. Les mesures de OI et OJ 
sont en fait les coordonnées de P. 

Par définition, on appelle cosinus de l’angle æ{(cos(æ)) la première 
coordonnée de P, soit OI, et sinus de l'angle « (sin (æ)) la seconde, soit OJ. 
C’est tout. Mais c’est bien plus qu’il ne paraît. Nous le verrons tout à 
l'heure. 

Regardez encore la figure. La droite OP coupe l’axe BT en U, et 
l'axe AZ en V. Toujours par définition, on appelle tangente de l'angle 
æ(tg(æ) ou tan(æ)) la coordonnée Z de V (soit AV), et cotangente de 
l'angle æ (cotg (æ) ou cotan (æ)) la coordonnée T de U, soit BU. 

Ces quatre valeurs ont bien évidemment un signe, positif dans le cas de 
figure. 
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De cette figure, on peut déduire des tas de propriétés très simples, mais 
essentielles. Par exemple, comme AO = OB = 1 (cercle de rayon 1), que 
OA'=OB'=-1 (orientation contraire), et que I est forcément situé 
entre A’et À, et J entre B'et B, on en déduit que le sinus et le cosinus sont 
forcément compris entre — 1 et 1. D’autre part, pour le triangle rectangle 
OIP et suivant le théorème de Pythagore : 


OP? = Of + PE. 


Or OP=1,0I= cos(x), PI = OJ=sin(«), donc: 


cos? (æ) + sin? (æ) = 1] 


Cette relation capitale est vraie pour tout angle. 
Suivant le théorème de Thalès, vu que IP est parallèle à AV, et que OIA 
d’une part et OPV d’autre part sont alignés, alors: 


AV _ IP 
OA OI 
Or OA=1, donc: 


sin (æ) 


LG ln cos (æ) 


De la même manière : 





cotan (æ) = _ _ 
donc 
cotan («) = = 


Toutes ces relations sont vraies pour tout angle. Cela explique que votre 
Amstrad n’ait pas de fonction cotangente, car il suffit d’inverser la 
tangente pour l’avoir. C’est aussi pourquoi on utilise peu la cotangente : 
désormais, nous n’en parlerons presque plus. 


Voilà l’essentiel de ce qu'il faut savoir en trigonométrie. Mais à quoi tout 
cela sert-il ? Regardez le schéma c de la Figure II.B. On y voit un triangle 
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rectangle en C, c’est-à-dire que l’angle en C est droit, ce qu’on note en y 
mettant un petit carré. 

Soit à l’angle en A. Les trois côtés du triangle seront appelés hypoténuse 
pour le plus long (AB), côté opposé à l’angle (BC), et côté adjacent à 
l’angle (AC). Pour connaître les valeurs de ces différents côtés, les uns en 
fonction des autres, connaissant 4, on dispose des trois formules suivantes : 


; te: tnt =? 


BC 
HEAR AB° AC 


AB’ 


ce qui se résume dans le mot mnémotechnique SOHCAHTOA, c’est-à- 
dire: Sinus égale côté Opposé sur Hypoténuse, Cosinus égale côté 
Adjacent sur Hypoténuse, Tangente égale côté Opposé sur côté Adjacent. 
Ces trois formules sont absolument fondamentales en géométrie. 

Notons qu’on les connaît déjà dans le cas du triangle OIP, car 
l’hypoténuse OP valant 1, on retrouve: 


sin (æ) = IP (= OJ); cos («) = OI; tan (x) = _ nn 





C’est à cause de ces formules dites du triangle que les sinus, etc., sont 
essentiels. Cela justifie le terme de trigonométrie qui signifie mesure du 
triangle. En effet, en géométrie, il y a des triangles partout. 

Pour mieux connaître ces fonctions trigonométriques, le schéma d de la 
Figure II.B vous en donne la valeur pour quelques angles : 


En 0 (0°) : sin (0) = 0 ; cos (0) = 1 ; tan (0) = 0 
Æ or : (ZT) 1. col) = 0: 
En (90°) : sin (?) 1; cos (7) 0; 


pas de tangente (division par zéro). 
En x (180°) : sin (x) = 0 ;cos(x) = —-1;tan (x) =0 
En (— 90°, ou + 270°) : sin (2) =—1;cos (2 =0; 


2 2 
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pas de tangente. 


Enfin au demi-angle droit, 


T ds , 
4 (45°), où sin et cos sont égaux : 


sin F) = 


cos F) = ;tan F) = ] 


Pour trouver commodément la valeur de ces fonctions en certains 
angles, on dispose de formules très utiles que je donne ici (valables pour 
tout x et tout y): 


—x? 


x+7? 


2x? 


FORMULES DE TRIGONOMÉTRIE 


sin (— x) = — sin (x); cos (— x) = cos (x); 
tan(—x)=—tan(x) 


sin(x +7) =—sin(x) ; cos (x +7) = — cos(x); 

tan(x+7)=tan(x) 

sin É — x = cos (x) ; cos É — x) = sin (x); 
T 1 

tn Es | x) tan (x) 

sin (2x) =2 - sin(x) : cos(x) 

cos (2x) = cos? (x) — sin? (x) = 2 : cos? (x) — 1 = 1—2 : sin?(x) 

sin(x+y)=sin(x) : cos(y) +sin(y): cos(x) 


cos (x + y) = cos (x) : cos(y) —sin (x): sin(y) 


sin(x—y)=sin(x) : cos(y) —sin(y): cos(x) 
cos (x — y) = cos (x) : cos(y) +sin (x): sin(y) 


Ces formules nous serviront assez fréquemment dans la suite. N’hésitez pas 
à vous y reporter si vous avez un doute. 
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3. LES FONCTIONS MATHEMATIQUES DE VOTRE AMSTRAD 


























Figure II.C 
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Outre les trois fonctions trigonométriques déjà vues, l’ Amstrad possède 
quatre fonctions que nous utiliserons de temps à autre, et sur lesquelles je 
souhaite dire juste quelques mots: il s’agit de la racine carrée sqr, de l’arc 
tangente atn, de l’exponentielle exp et du logarithme log. 


La Figure II.C représente quelques fonctions de l’ Amstrad. En effet on 
peut représenter une fonction graphique par y = fonction de x, en faisant 
varier X. 

Ainsi, en haut et à gauche, on a y = sin (x). La courbe obtenue porte le 
nom de sinusoïde. On reconnaît quelques valeurs du sinus (voir ci-dessus). 
On vérifie que le sinus oscille entre — 1 et 1. Enfin, on remarque que la 
courbe se répète tous les 27 radians, ce qui n’a rien de surprenant puisque 
les angles eux-mêmes se répètent. On dit que cette courbe est périodique. 
Notez que la courbe du cosinus est exactement la même, mais décalée de 
xr/2 vers la droite, de sorte que le maximum, le sommet, se trouve sur l’axe 
des v. 

Juste en dessous, la courbe y = tan (x). Cette courbe est infinie vers le 
haut et le bas, lorsque x s'approche de + x/2 (rappelez-vous que la 
tangente n'existe pas pour ces valeurs, elle serait infinie). Là encore, la 
courbe est périodique, mais de période x (voir tan (x +7) = tan (x)). 

En haut à droite, la courbe en traits pleins est la courbe y = x?. 

Elle porte le nom de parabole. En pointillé, la courbe y‘= sqr (x). C’est 
aussi une parabole, mais couchée, et il en manque la moitié. Ces deux 
fonctions sont dites réciproques, en ce sens que si y = sqr (x), alors 
x = y”, et inversement si y = x?, alors x = sqr (y)(). Notons que la 
courbe en pointillé se trouve entièrement à droite de l’axe Oy: la racine 
carrée d’un nombre négatif n'existe pas. 

La courbe représentant la fonction atn n’est pas représentée. Atn (arc 
tangente) est la réciproque de la tangente : si y = atn (x), alors tan (y) = x; 
ou encore, si vous préférez, x =tan(atn(x)). Votre Amstrad donne l’atn 
entre — x/2 et x/2. N'oubliez pas, en effet, que 


tan(y)=tan(y+7)=tan(y +2) =... 


et donc que l’arc tangente est déterminée à un certain nombre de fois x 
près (on dit : “modulo x”). 


(1) Avec x et y positifs. 
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Le dernier schéma, en bas à droite de la figure, représente les fonctions 
exp et log. La première, en traits pleins, a une valeur facile à comprendre ; 
pour tout x, exp (x) = e* (e à la puissance x), où e = exp (1) est un certain 
nombre égal à 2,71828183... dont l’origine serait trop compliquée à 
expliquer ici. Le logarithme dit népérien (du nom du mathématicien 
Neper), ou naturel, est la réciproque de l’exponentielle : 


y=log(x) si x=exp(y)=e” 


Par exemple, 1 = exp (0) et e = exp (1), donc log (1) =0 et log(e) = 1. 

Vous pouvez encore vérifier cela en prenant un nombre au hasard, par 
exemple 3. Tapez sur votre ordinateur : e = exp (1). Puis : PRINT exp (3). 
Vous obtenez 20,085... Puis: PRINT e ? 3. Vous obtenez le même 
nombre. A présent, tapez: PRINT log(20,085...) (en recopiant le 
nombre). Vous obtenez 3. C.Q.F.D. 

L'intérêt pratique du logarithme sort du cadre de cet exposé. Celui de 
l’exponentielle est très variable. Il permet par exemple de calculer 
x’ =exp(y : log(x)). 

Notons que la fonction 10* est semblable à exp (qui est e*), en 
remplaçant e par 10. Elle a aussi une réciproque, le logarithme décimal, 
que votre Amstrad note log 10: log 10 (x) = y équivaut à x = 10”. 

Cet aperçu des fonctions mathématiques de votre ordinateur étant fait, 
nous allons passer à un sujet tout différent, en nous replongeant au cœur 
de la géométrie. 


4._ LES VECTEURS, UNE CHOSE BIEN COMMODE 





Nous utiliserons beaucoup les vecteurs dans ce livre. Non qu’ils soient 
absolument essentiels, mais ils sont si commodes que ce serait dommage de 
s’en priver. 

Pour expliquer de quoi il s’agit, je dois d’abord dire ce qu’est un bipoint. 
Un bipoint, c’est un couple de points. C’est tout. Par exemple, si À et B 
sont deux points de l’espace, (A,B) est un bipoint. On caractérise un 
bipoint par quatre choses: 


e Son origine, c'est-à-dire son premier point À (attention de ne pas les 
inverser). 
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e Sa longueur, ou norme : c’est la distance entre A et B (mesurée en unités 
arbitraires). 
e Sa direction : c’est une droite, la droite AB, passant par A et B. 


e Son sens : de A vers B (pour le distinguer de (B, A)). 


On dit que deux bipoints sont équivalents s’ils ont même norme, même 
sens et même direction : seule l’origine change. 

On appelle vecteur l’ensemble de tous les bipoints équivalents à un 
bipoint nommé (A, B) : c’est le vecteur AB que l’on note en caractères gras 
pour le distinguer de la droite AB. 

On caractérise un vecteur par sa norme, sa direction et son sens qui sont, 
vous l’avez deviné, ceux du bipoint (A,B). 

Cela vous paraît sans doute artificiel et bizarre, mais vous avez déjà 
utilisé des vecteurs. Ainsi, quand vous dites que le vent souffle à 80 km/h 
dans le sens nord-sud, et du nord, vous donnez ainsi la norme (80 km/h), la 
direction (axe nord-sud), et le sens (du nord vers le sud) d’un vecteur qui 
est ce que l’on appelle le vecteur-vitesse du vent. 

Un vecteur peut être caractérisé par des coordonnées. En effet, soit V un 
vecteur donné, et O l’origine d’un repère Oxyz. Il existe un point K tel que 
OK = V (vecteur OK égale vecteur V, ce qui signifie aussi que le bipoint 
(O,K) appartient à V : on dit que (O, K) est un représentant du vecteur V). 
Ce point K est unique. Il possède dans le repère Oxyz trois coordonnées 
(x, y, z). On les appelle aussi coordonnées de V. Donc, pour résumer, les 
coordonnées d’un vecteur sont celles du second point du représentant de ce 
vecteur placé à l’origine des axes. 

On ne peut pas vraiment dessiner un vecteur. On peut dessiner un de ses 
représentants. En mettant une flèche au bout, on montre qu’il s’agit bien 
de représenter un vecteur, comme sur la Figure II.D, schéma a. 
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HOMOTHETIE ROTATION 


Figure IL. D 
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Ce schéma est destiné à illustrer deux opérations sur les vecteurs, qui 
nous seront extrêmement utiles, surtout la première. 

Soit deux vecteurs U et V, de coordonnées (0,41, u2) et (vo, V1, v2). On 
appelle produit scalaire de ces vecteurs le scalaire (c’est-à-dire le nombre, 
par opposition à un point ou un vecteur): 


U-V=w : Vo+u  V+w'v 


Ce produit scalaire est très intéressant car il donne le cosinus de l’angle « 
qui sépare les deux vecteurs. En effet, si u et v sont respectivement les 
normes de U et V,ona: 


U:V=u:v:cos(x) 
Comme 
u = Sqr (16 + uf + u3) 


on obtient la formule : 


(Uo * Vo+ui Vi +u:v) 


PE ee ren) 


qui permet de trouver le cosinus de l’angle séparant deux droites, comme 
nous le verrons. 

Seconde opération, le produit vectoriel dont le résultat est un vecteur W. 
On le note W = U A V. Les coordonnées de W sont: 


WoTUi VU Vi, Wi—U2 Vo Ugo V2; W2—Uo: Vi — Ui Vo 


C’est un vecteur qui est perpendiculaire au plan qui contient U et V, et 
dont la norme est w = u - v - abs (sin («)), ce qui permet de trouver le sinus 
de « (voir figure). 

Notons encore une chose : lorsque U et V sont perpendiculaires (æ = 90°) 
leur produit scalaire est nul (car cos (90°) = 0). S’ils sont parallèles, (œ = 0), 
c’est leur produit vectoriel qui est nul (car sin (0) = 0) : en effet un vecteur 
de norme nulle est dit nul ; ses trois coordonnées sont égales à 0. C’est le 
cas du vecteur AA, pour n'importe quel point A. 
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5. APPLICATION DES VECTEURS : EQUATION D'UN PLAN, 
D'UNE DROITE 


Soient trois points À, B, C. Il existe un unique plan P qui passe par ces 
trois points (à condition qu'ils ne soient pas alignés). Soit P ce plan, et M 
un point de coordonnées (x, y, z). Comment savoir si M appartient au 
plan ? 

Il faut pour cela trouver l’équation du plan. Voici le raisonnement. Soit 
U et V les vecteurs AB et AC. P est le plan passant par A et dirigé par U et 
V. Soit W=U/ V. Ce vecteur est perpendiculaire au plan P (voir figure). 
Il est donc perpendiculaire à toute droite contenue dans P, ou à tout 
vecteur. Or si M est contenu dans P, AM est un vecteur contenu dans P. 
Donc AM : W=0. C’est l'équation de P. Mettons-la en clair. 

Le vecteur AB a pour coordonnées la différence des coordonnées de B et 
A, soit ((bo — ao), (b1 — a;),(b2 — a;)). En calculant aussi les coordonnées 
de V, on trouve celles de W: 


Wo= (bi — ai) * (c2— 42) — (b3— a2) : (ci — &) ; etc. 


AM a pour coordonnées ((x — ao), (y — &),(z — 4)); donc AM : W=0 
s'écrit : 


Wo * (X—@o)+w : (—-a)+w:(z-a@)=0 
ou encore : 
WoXx+w:y+w:z-k=0 
où k vaut: 
Wo ‘ d0+Wi 4 +W2° @ 
Cette égalité est l'équation du plan P. 
Pour une droite, le principe est à peine différent. Soient A et B deux 


points (distincts), et D la droite passant par A et B. Comment savoir si M 
est sur cette droite ? Très simple : si U est le vecteur AB, M est sur D si AM 
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est colinéaire (c’est-à-dire parallèle) à U. Cela se traduit comme ceci: il 
existe un nombre k tel que: 


x=4o+k(bo—a@o); y=a+k(b;-a); z=a;+k(b;-—a;) 


Ces trois égalités sont appelées équations paramétriques de la droite, car 
elles dépendent d’un nombre k, qui est inconnu. Elles équivalent en 
général aux deux équations suivantes : 

Le me (= k, d’ailleurs). 

bo—4o bi—ai b:-a 
Ces deux équations sont dites intrinsèques, car il ne s’y trouve aucun 
paramètre indéterminé. 

Pour finir avec tout cela, quelques mots de vocabulaire. Un vecteur W 
perpendiculaire à un plan P est dit normal à ce plan. Un vecteur U joignant 
deux points distincts d’une droite D est dit directeur de la droite. 

Enfin, si ces vecteurs sont normés, c’est-à-dire de norme un (ne pas 
confondre avec normal !), ils s’appellent le vecteur normal à P et le vecteur 
directeur de D, quoiqu'il y en ait deux: le vecteur en question, et son 
opposé (— W ou —U, c’est-à-dire le même vecteur, mais avec le sens 
inverse). 


6. LES TRANSFORMATIONS DE L'ESPACE: 


PROJECTIONS, SIMILITUDES... 





On appelle application de l’espace dans lui-même une fonction qui, à un 
point de coordonnées données (dans un repère fixe déterminé à l’avance), 
fait correspondre un autre point. Si (x, y, z) sont les coordonnées du point 
de départ M, et (x1, y1, z1) les coordonnées du point d’arrivée M, il suffit 
d'écrire x1, y1 et z, comme des fonctions de x, y, z, pour avoir la 
transformation. Toutefois, il y a un autre moyen d'expliquer ce que fait 
telle ou telle transformation ou application de l’espace: l’expliquer 
géométriquement. 


C’est ce que je compte faire dans ce paragraphe où nous allons étudier 
quelques transformations très simples de l’espace. Les calculs de 
coordonnées seront donnés au paragraphe suivant. 
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Tout d’abord, la plus simple est la translation de vecteur V. Le point (dit 
image) M, est tel que MM, = V, tout simplement. En gros, cela consiste à 
déplacer les points dans une direction, et d’une distance données. Par 
exemple, un ballon poussé par le vent subit une translation. 

Ensuite, la projection. Voyez la Figure II.D, schéma b. Un plan P étant 
donné, on appelle projection de M sur P le point M, tel que : M, est sur P 
et MM, est perpendiculaire à P. On voit aussi sur le dessin la projection 
d’une sorte de cube sur P (il en sera de même de toutes les transformations, 
pour les rendre plus claires). Notez que tous les points de la droite MM; 
ont M, pour projection sur P. 

La symétrie est expliquée sur le même dessin. M, est le symétrique de M 
par rapport au plan P, ce qui veut dire que MM, est perpendiculaire à P 
(comme MM), et que les distances MM, et MM, (distance de M à P, et 
distance de M; à P) sont égales. Notez que M est aussi le symétrique de 
M3. Si vous vous regardez dans un miroir, l’image que vous y voyez est 
votre symétrique par rapport au plan du miroir. 

L’homothétie par rapport à un point O est telle que M, est sur la droite 
OM, et que OM, = k : OM, où k est un nombre constant que l’on appelle 
rapport de l’homothétie (k = 2 sur la figure). Une homothétie grossit ou 
diminue les objets, mais garde leur forme et leur orientation inchangées. 
Cette transformation est illustrée par le schéma c de la Figure II.D. 

Enfin, la rotation d’axe D et d’angle 4, visible sur le schéma d de la 
même figure, est telle que si P est le plan passant par M perpendiculaire à 
D, et H l'intersection de P et D, alors: M; est dans P ; la distance de M, à 
H est la même que de M à H; et l’angle MHM, est égal à 4. Pour 
simplifier, une rotation consiste à faire tourner un objet. 

Ces transformations peuvent se faire séparément, évidemment, ou bien 
à la suite. Si, par exemple, vous faites une rotation r puis une homothétie 
h, cela fait une certaine transformation que l’on appelle composée de r par 
h (et qu’on note her) (1), 

On englobe sous le nom de similitudes toutes les applications qui sont les 
composées de symétries, de rotations, de translations et d’homothétie, car 
l’objet obtenu ressemble tout à fait à celui de départ. Par exemple, si vous 
prenez un stylo et que vous le jetez par terre, vous aurez fait sur lui une 
rotation-translation, donc une similitude. 

Pour finir, sachez qu'il est possible d’inverser une application dans 
certains cas, c’est-à-dire d’en trouver l'inverse, l’application qui à M, fait 
correspondre M, au lieu du contraire. 

(1) Lire: h ROND r. 
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Voici les inverses des transformations vues : 

e L’inverse d’une translation de vecteur V est la translation de vecteur 
— V. 

e Une projection n’a pas d’inverse. 

e L'inverse d’une symétrie, c’est. elle-même (rappelez-vous, je vous ai 
dit que le symétrique de M, était M). 

e L’inverse d’une homothétie de centre O et de rapport k est l’homothétie 
de centre O et de rapport 1/k. 


e L’inverse d’une rotation d’axe D et d’angle à est la rotation d’axe D et 
d’angle — à. 


7._ APPLICATIONS AFFINES ET MATRICES 


On dit qu’une transformation de l’espace est affine si elle s'exprime sous 
la forme : 


X=m(i,1)-x+m(1,2) :y+m(1,3) : z+c(1) 
m=m(2,1)-x+m(2,2) : y+m(2,3) : z+c(2) 
Z=m(2,1)-x+m(3,2) : z+m(3,3) : z+c(3) 
où les m(i,j) (i et j variant de 1 à 3) et les c(k) (idem pour k) sont des 
constantes qui caractérisent l’application affine. Nous allons voir que 
toutes les applications vues au paragraphe précédent sont affines. 


Les trois relations ci-dessus s'expriment de manière plus simple sous la 
forme : 


où M désigne la matrice contenant les coefficients m (i,j), matrice à trois 
colonnes et trois lignes ; X,, X et C sont les matrices contenant (x:, y1,z1), 


(x, y, z) et les c(k), respectivement : ce sont des matrices à une colonne et 
trois lignes. 
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Pour faire la somme de deux matrices, c’est tout simple, on additionne 
leurs coefficients terme à terme. Ainsi, la somme de M et de P (de 
coefficients m(i,j) et p(i,j) évidemment) est la matrice Q telle que 
q{i,j) = m(i,j) + p(i,j), pour tout i et tout j. Cela exige que M et P aient 
autant de colonnes et de lignes, sinon la somme n’a pas de sens. 

Le produit est un peu plus compliqué. Pour pouvoir le faire, il faut que le 
nombre n de colonnes de M soit égal au nombre de lignes de P. Alors la 
matrice Q = M : P a autant de lignes que M et autant de colonnes que P. 
Ses coefficients sont, si À est leur numéro de ligne et j leur numéro de 
colonne : 


a) =m(t1 :p()+m(,2) :p(2,))+..+m(in) :p(n,j) 


Remarque capitale 


M : P n’est pas forcément égal à P - M, en admettant que les deux 
produits soient possibles, ce qui n’est pas sûr. 


Vérifions que l’on peut calculer M : X+C. Tout d’abord, M a trois 
colonnes, et X trois lignes. On peut donc calculer M : X. Cette matrice a 
alors autant de lignes que M, soit trois, et autant de colonnes que X, soit 
une. C’est le cas également de C. On peut donc faire la somme : C.Q.F.D. 

Une translation est telle que M=Id (matrice Identité, telle que 
Id : P=P - Id = P, quelle que soit la matrice P)(1 et C est la matrice des 
coordonnées de V:c(1) = vo,c(2) = v:,c(3) = v2. Donc X;, =X +C, pour 
une translation. 

Dès lors, toute application affine est composée d’une application linéaire 
(type X1 = M : X) et d’une translation (ajouter C au résultat). 

Les autres applications vues sont linéaires. Nous allons en voir les 
matrices dans des cas particuliers. 


Projection sur le plan xOy 
1 0 0 
M=1]0 1 0 
0 0 0 


1 0 0 
(1) Id =|0 1 0 
0 0 1 
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Symétrie par rapport au plan xOy 


1 0 0 
M =|0 1 0 
0-0: 1 


Homothétie de centre O et de rapport k 
k 0 0 
M =]0 k 0 
0 0 Kk 


Rotation d’angle 4 (c désigne le cosinus de 4, et s son sinus) 


c —s 0 
autour de Oz M=|s c 0 


0 01 


pi 


c O0 —s 
autour de Oy M=1]0 0 


s 0 C 


1 0 0 
autour de Ox M=10 c -s 


0 s C 


Si j'ai donné plus de détails sur la rotation, c’est qu’elle permet de 
trouver toutes les similitudes possibles. En effet, si l’on veut faire, par 
exemple, une symétrie autour d’un plan P autre que xOy, il suffit de 
trouver un repère dans lequel ce plan soit XOY (OXYZ étant le nouveau 
repère). On peut passer d’un repère à l’autre par une certaine rotation R 
(qui est elle-même le produit de deux ou trois rotations du type donné 
ci-dessus, en général). S étant la matrice de la symétrie par rapport à XOY, 
cette symétrie a pour matrice dans Oxyz:M=R !-S-R,où R° ! est 
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l'inverse de R, c’est-à-dire la matrice de la réciproque de la rotation (qui 
s'obtient en changeant les angles de signe). Nous aurons l’occasion de 
revenir sur ce point dès le prochain chapitre, par un exemple concret, ce 
qui sera sans doute plus clair. 

Je pense qu’à présent vous êtes absolument paré pour aborder à fond le 
graphisme en trois dimensions. 


A AGE 


Ill 
L'ART DU VOYEUR OÙ 
COMMENT REGARDER SOUS 
TOUS LES ANGLES 





Nous allons à présent passer aux choses sérieuses, c’est-à-dire commencer à 
raisonner et à programmer effectivement en trois dimensions. 

Toutefois “qui veut voyager loin ménage sa monture” ; nous allons donc débuter 
par quelque chose de simple et facile à programmer, cela nous donnera d’autant 
plus de chances de parvenir à des choses nettement plus complexes. 

Tout au long de ce livre, nous aurons besoin, d’une manière ou d’une autre, de 
repérer certains points dans l’espace. Nous utiliserons pour cela un repère 
(précisément), c’est-à-dire un point O fixé et trois axes Ox,Oy,Oz comme 
expliqué au Chapitre II. Par conséquent, pour commencer, nous allons tâcher de 
dessiner sur l’écran simplement ces trois axes, tout seuls. 

Mais, direz-vous, cela ne sert à rien! 

C’est tout à fait exact. Mais cela permettra de nous familiariser avec ce fameux 
repère, de mieux le percevoir dans l’espace, choses qui ne sont pas aussi simples 
qu’on pourrait le croire au premier abord. C’est pourquoi je vous déconseille 
vivement de sauter ce chapitre, ou de ne pas essayer les programmes qui s’y 
trouvent, même si ces notions vous paraissent simples, ou si elles vous sont 
familières : il n’y a là que du temps gagné. 


1. TRACER LE REPERE SOUS UN POINT DE VUE DEFINI 
PAR DEUX ANGLES EN SPHERIQUES 


Le titre de ce paragraphe vous a peut-être intrigué. Expliquons-le. 

Ce n’est pas tout d’avoir l'intention de réaliser une vue d’un repère, ou 
plus généralement d’un objet. Il faut encore la réaliser en pratique. Et 
pour cela, votre ordinateur a d’abord besoin de savoir où se trouve 
l'observateur (c’est-à-dire vous-même) par rapport à l’objet qu’il est censé 
voir. On pourrait pour cela utiliser les points cardinaux (nord, est, etc.) 
mais ce n’est guère commode. Nous allons tout simplement utiliser les 
repères de l’espace qui sont représentés en Figure II.A, Chapitre II. 

Tout d’abord, l’objet est supposé positionné en O, c’est-à-dire à l’origine 
du repère. Quant à l’observateur, jusqu’au Chapitre X, il sera supposé 
“infiniment loin”, c’est-à-dire que le point Y où se trouvent ses yeux est à 
une distance de O beaucoup plus grande que la taille de l’objet. 

Pourquoi cela ? Eh bien, il se trouve qu’ainsi, il suffit de projeter l’objet 
sur un plan E (écran) pour avoir une image qui paraisse vraie, alors que si 
l’objet était tout près, il serait déformé, comme sur ces photos où l’appareil 
a été placé tout près du nez du photographié : ces déformations engendrent 
les fameux points de fuites, de maniement très complexe. (Voir 
Chapitre X.) 

Plutôt que la position exacte de Y, c’est donc le plan E, orthogonal 
(c’est-à-dire perpendiculaire) à la droite OY, qui nous intéresse. Or, ce 
plan est susceptible de bouger, puisqu’on veut voir notre objet sous des 
aspects divers. Il faut donc décrire sa position d’une manière ou d’une 
autre ; nous allons utiliser ici son vecteur normal. 

Ce vecteur N est l’unique vecteur (au signe près toutefois) perpendicu- 
laire au plan E et unitaire (c’est-à-dire, rappelons-le, dont la somme des 
carrés des coordonnées vaut 1). Appelons p, q, r ses coordonnées 
cartésiennes. Ces trois coordonnées sont aussi celles d’un point n tel que le 
vecteur On soit égal à N. Et ce point n a aussi des coordonnées sphériques 
r, 0 et y, que par abus de langage nous appellerons coordonnées 
sphériques du vecteur N. 

Or, ce vecteur est unitaire, donc r = 1 (voir expression de r en fonction 
des coordonnées cartésiennes). Restent donc les deux angles 8 et y, et 
maintenant le titre du paragraphe doit vous sembler plus clair. 

On a donc les valeurs de p, q et r en fonction de ces angles: 


p = cos (y) : sin (8) qg = sin (y) : sin (6) r = cos (8) 
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Vérifiez ainsi que p° + qg°+r = 1, sachant que cos? (â) + sin? (4) = 1 pour 
toute valeur de à. 

D'autre part, votre écran, c’est-à-dire le plan E, est doté par l'ordinateur 
d’un repère de coordonnées cartésiennes du plan (voir Figure II.A) que 
nous noterons O, X, Y pour éviter toute confusion. 

Un point de coordonnées (x,y,z) étant donné, ainsi qu’une direction 
d'observation N de coordonnées (p,q,r), ce point a pour projection sur 
l’écran un point de coordonnées (X, Y). 

Nous admettons les formules suivantes : 


=(4**x=p y) LRSES PE DE )) 
OT NÉS R 


avec 
R= Vp? + q° 


formules qu’on ne saurait trouver simples. 
D'où l'utilité des angles. En effet le lecteur vérifiera que R = sin (8). 
Dès lors, tout est simple : 


X= x :sin(#ÿ) — y : cos(y) 
Y=2z:sin(0)—(x : cos(y) + y : sin(y)) : cos (6) 
A présent, nous allons appliquer ces formules dans le Programme IIL.1 : 


FROCFRAMME III. 1 





s2=8INCtheta) 
456 CLS:'ORIGIN 324,26@ 
468 FLOT à,8.3 
476 TAG 
489 DRAU 200ks1,-268@4c1kc2:PRINT"x"; 
439 PLOT @,6,3 
59 DRAU -204#c1,-2008%s1%c2: PRINT"y"; 
519 FLOT @,@ 
529 DRAH 4,26@*#s2:PRINT"z") 
539 TAGOFF 
546 FENH 1 
559 RETURN 





Expliquons ce programme. 

Il commence à la ligne 400. En effet, nous aurons encore à l’utiliser 
(n'oubliez pas de le conserver). Pour l'instant, en lignes 10 et suivantes, 
choisissez le mode et les couleurs (le dessin est fait en couleur 3), et mettez 
aussi un INPUT thêta et un INPUT psi. 

En lignes 410 à 430, on appelle c;, c>, etc., les cosinus et sinus de nos 
deux angles, afin que l’ordinateur ne perde pas de temps à les recalculer 
plusieurs fois. 

En 450, on efface l'écran et l’on place l’origine des coordonnées de 
l'écran O au centre de celui-ci. En 460, on y place aussi le plot, en 
choisissant à 3 la couleur de tracé. 

En 470, le TAG permettra d’imprimer le nom des axes à leur extrémité. 

Ensuite, on trace les axes proprement dits. Non pas en entier (ils sont 
infinis), mais en traçant un morceau compris entre O et un point situé sur 
l'axe à tracer, à une longueur donnée (ici 200). On applique donc les 
formules ci-dessus au point O (on obtient X=Y =0), puis au point 
(200,0,0) pour l’axe Ox, au point (0,200,0) pour Oy, et au point 
(0,0,200) pour Oz. 

Le RETURN de la ligne 550 signale que le programme doit être appelé 
par un GOSUB. Cela vous permet de l’exécuter plusieurs fois en 
changeant les angles, avec un FOR-NEXT, ce que je vous conseille. 

A présent, faites tourner votre programme, et regardez comme le repère 
évolue. N'hésitez pas à rajouter cette ligne : 


545 LOCATE 1,25:PRINT “psi=”psi; :PRINT “theta="theta; 


et étudiez la position des axes en fonction des deux angles. 
Vous serez aidé par la Figure IT. A et par les exemples de la Figure ITA. 





2. AUTRES DEFINITIONS DU POINT DE VUE 


RE 





Nous avons choisi dans tout cet ouvrage le point de vue donné par deux 
angles en sphériques, pour des raisons de simplicité, quand c’était possible. 
Mais il nous arrivera d’avoir un point de vue donné simplement par un 
vecteur N' de coordonnées p', q', r', même pas forcément unitaire. 
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Comment dès lors obtenir p, q et r ou, mieux, les deux angles 8 et y ? On 
utilisera les formules suivantes: si 


R=sqr(p'?+q'?+r'?) 


D'autre part: 


, 12 12 
y= ATN(#) et 6= ATN (XP +9) 


Ces formules nous seront bien utiles dans la suite ; elles sont données ici à 
titre indicatif. 

Dans un autre ordre d’idées, si vous avez fait marcher le programme 
IIT.1, vous aurez remarqué que l’axe Oz reste toujours vertical, quelles que 
soient les valeurs des angles choisies : le repère est bien vu sous tous ses 
angles, mais il reste vertical, on ne peut le renverser. 

Cela n’est possible qu’à condition de rajouter un troisième angle (mais 
oui !), noté  (phi), et nommé rotation propre car il décrit la rotation de 
l’objet autour de l’axe visuel O-Observateur qui reste fixe, alors que les 
deux autres angles traduisaient un changement de cet axe visuel. 

Les nouvelles coordonnées projetées de l’écran, notées X' et Y’ se 
déduisent des anciennes X et Y par les formules de rotation du plan: 


X'=X c+Y:s; Y'=-X-5s3+Y:0c 


avec, vous l’aviez deviné, c3 = cos (g) et s3 = sin (@). 

A vous à présent, si vous le souhaitez, d’adapter le Programme IIL.1, et 
tous ceux qui suivront pour pouvoir faire tourner l'écran. 

Pour ce qui est de moi, mes axes Oz resteront verticaux ! 


ES de 


3. APPLIQUER AUX AXES UNE TRANSFORMATION DE L'ESPACE 








Nous avons vu au Chapitre II, Paragraphe 4, qu'il existait de 
nombreuses transformations de l’espace nommées similitudes (car le 
résultat après transformation ressemble à ce qu’on avait au départ), 
définies par des matrices. 

Comment appliquer ces transformations à nos axes ou, plus tard, à 
d’autres objets ? 

C’est tout simple, il suffit d'appliquer les matrices aux triplets (x, y,z), 
comme défini au Chapitre II.4. 

En fait, nous l’avons déjà fait : pour trouver X et Y, nous avons appliqué 
à (x,y,z) la matrice M: 


Si — Ci 0 
M =l-c © — C°S S2 
$2 * Ci $2 ‘ Si C2 


Nous avons obtenu un nouveau triplet (X, Y, Z) et nous n’avons pas tenu 
compte de Z. 
A présent, vérifiez que M est le produit de ces trois matrices : 


1 0 0 0 —-1 0 C1 51 0 
0 C2 S2 L — 1 0 0 e [—S1 C 0 
0 — $2 C2 0 0 1 0 O0 1 


Reportez-vous au Chapitre II.4 et essayez de savoir exactement de 
quelles matrices il s’agit; pouvez-vous expliquer cela à l’aide de la 
Figure II.A ? (Question Ill-a.) Sinon, n’utilisez plus de matrices par la 
suite, ou relisez le Chapitre Il.4. De toute façon, nous en utiliserons le 
moins possible dans la suite. 

Pour le moment, nous allons nous contenter de nos deux angles de 
sphériques ; ils suffiront largement à notre plaisir pendant un bon moment ! 


she 


4. ANIMATION 





Plutôt que de devoir écrire de nouvelles valeurs de ces deux angles, ou 
que de les laisser varier sans contrôle, il est évidemment plus intéressant de 
pouvoir les changer soi-même, avec le clavier ou une manette de jeu. 

C’est l’objet du Programme III.2, que nous aurons également l’occasion 
de réutiliser par la suite. Pour l'instant, nous allons l’additionner au 
Programme III.1 et remplacer les GOTO ‘dessin’ par des GOSUB 400. 


FROGRAMME 1III.-Z 





N.B.:L'indication ‘dessin’ signifie:"li9ne où se trouve le dessin à 


exécuter" (Par exemPle 14 line 498 avec le Programme III.1), 


1300 
1319 
1320 
1339 
1349 
1350 
136Q 
1370 
1380 
1308 
1319 
1920 
1930 
1349 
1950 


‘mansuassssaseszs==s2s2===22s2as22sessesssazszs Choix clavier/manette 
CLS:PRINT"Choisissez entre:":PRINT 

PRINT"- Utiliser une manette de jeu (aPPusez sur M)" 

PRINT"- Utiliser le clavier (aPPuyez sur C)" 

WHILE INKEYC38)=-1 AND INKEYC62 )=-1 : HEND 

IF INKEYC383<>-1 THEN GOSUB 2769 ELSE GOSUB 2599 

CLS 

theta=45:psi=45 

GOTO ‘dessin’ 

’mansssazrssassass=sssenecenesezesesezcsussezz Test des touches reunies 
IF a=9 THEN b=19 

IF a=32 THEN b=28 

IF a=128 THEN b=5 

IF 3=169 THEN b=45 

RETURN 

lRTSSSESSSRSESSS 2 2ESLE RSS S=SSEMESSSSESS=SSSSa=e22S22 Touches de rotation 
3$=INKEYS#:IF a$="" GOTO 2919 

8=INKEYCkK12:1IF a<>-1 THEN GOSUE 1900:Psi=Psi-b:GOTO ‘dessin’ 
a=INKEYCkK2):1IF a<>-1 THEN GOSUB 1909:Psi=Psi+b:GOTO ’ dessin’ 
3=INKEYCkK32:1IF 3<2-1 THEN GOSUB 1900 :thetastheta-b:GOTO ‘dessin’ 
a=INKEYCk42:IF a<>-1 THEN GOSUB 1980 :theta=theta+b:GOTO ’ dessin’ 
IF INKEY(792<>-1 THEN CLS : END 

GOTO 2910 

lRasxmcas22zs22s2z==2x22==s22eSs=c=es2es2222=x [Indications Pour le clavier 
CLS:k1=234:k2227:k3=67:k4=59 

PRINT'"'APPuyez sur l’une de ces touches" 

PRINT:PRINT"_ Q :seul,ou avec <CTRL>,ouù avec" 

PRINT"'<SHIFT>,ou avec les deux,Pour avoir un" 

PRINT'basculement vers le bas de,resPective-" 

PRINT'ment 19,5,2@ ou 45 degres." 

PRINT:PRINT"_ W :seul,ou avec <CTRL)>,ou avec" 

PRINT'<SHIFT)>,ou avec les deux,Pour avoir un" 

PRINT"'basculement vers le haut de,resPective-" 

PRINT'ment 1@,5,20 ou 45 degres." 

PRINT:PRINT"_ P :seul,ou avec ...(idem) Pour des" 
PRINT"'rotations Positives autour de l’axe 2." 

PRINT:PRINT"_ O :seul,ou avec ...Cidem) Pour des" 
PRINT'rotations negatives autour de l’axe z." 

PRINT:FRINT"_ <DEL}» Pour arreter le Pro9ramme." 

LOCATE 1,253:PEN 3:PRINT"APPusez sur la barre Pour commencer" 
WHILE INKEYC47 3=-1 : WEND 

RETURN 


lraszsssassassessassz-2sesessez==essezsz2=se [Indications Pour la manette 


216% 


2718 CLS:k1=74:k2=75:k3273:k4=72 

2729 PRINT"'APPuyez sur l’une de ces touches :" 

2730 PRINT:PRINT"_"+CHR#C2412+" :seul,ou avec <SHIFT> Pour " 
274Q PRINT"avoir un basculement vers le bas de," 

2758 PRINT'respectivement 14 ou 29 deSres." 

2768 PRINT:PRINT"_"+CHRS(249)+" :seul,ou avec <SHIFT> Pour " 
2778 PRINT'avoir un basculement vers le haut de," 

2789 PRINT"'resPectivement 19 ou 28 degrees." 

279@ PRINT:PRINT"_"4+CHR#SC242)+" :seul,ou avec <SHIFT> Pour des" 
2899 PRINT"'rotations Positives autour de l’axe z." 

2819 PRINT:PRINT"_"+CHRSC243)+" :seul,ou avec <SHIFT)> Pour des" 
2820 PRINT"'rotations neSatlves autour de l'axe z." 

2830 PRINT:PRINT"_ <DEL) Pour arreter le ProSramme." 

2848 LOCATE 1,25:PEN 3:PRINT"APPuyez sur la barre Pour commencer" 
2859 WHILE INKEYC 47 )=-1 : HEND 

286 FETURN 





Ce Programme III.2 est assez parlant. Les lignes 1300 et suivantes vous 
permettent de choisir entre l’utilisation du clavier, moins commode mais 
plus souple car elle vous permet de choisir entre quatre valeurs 
d’incrément des angles (voir les instructions, lignes 2500 et suivantes), et 
celle de la manette, qui ne vous laisse que deux choix, la touche CTRL 
étant sans effet sur la manette. 

Bien sûr, si vous n’avez pas de manette, ne tapez pas les lignes 1310 à 
1350, ni les lignes 2700 et suivantes. 

Les lignes 2000 et suivantes testent le clavier pour savoir quelles touches 
sont pressées. Si l’on appuie sur Q, W, O ou P pour le clavier, ou si l’on 
déplace la manette en mode manette, elles ajoutent une valeur b égale à 5, 
10, 20 ou 45 (suivant que la touche a été pressée seule ou non — voir 
instruction INKEY en page 8.19 de votre manuel), ou la retirent, soit à 6, 
soit à selon la touche pressée. 

Si ces lignes vous paraissent obscures, essayez tout de suite le 
programme en suivant les instructions qui s’affichent ; vous ne tarderez pas 
à comprendre. 

Notez enfin que la ligne 1370 initialise les deux angles à 45°, sauf si vous 
avez oublié de mettre, avec le choix du mode en début de programme, 
l'instruction DEG ! 

Le programme va donc vous afficher en premier ce que vous voyez en 
Figure IIT.A, cadre 1. Cette configuration est dite isométrique car les trois 
axes ont alors la même longueur (compte tenu de ce que la lettre z a effacé 
une partie du troisième); les objets vus en isométrique sont plus 
harmonieux et plus faciles à se représenter dans l’espace, d’où le choix fait 
au Chapitre IX pour les surfaces en trois dimensions. 

Appuyez à présent sur votre manette ou sur le clavier (suivant les 
instructions) ; faites varier vos angles. 
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Essayez d’arriver exactement aux mêmes configurations que celles de la 
Figure IIT.A (vous n’y parviendrez en fait qu’avec le clavier). 
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D'ailleurs, jetons un coup d’œil sur cette figure. Dans le cas du cadre 2, 
avec quel plan E est-il confondu ? Quel est alors le vecteur normal ? Est-ce 
compatible avec les valeurs données des angles ? (Question III.b.) 

Pour les cadres 3 et 4 de la même figure, les configurations des axes sont 
exactement les mêmes, mais x et y sont inversés. Or il se trouve que, d’une 
part, l’interversion de deux axes change un repère direct en un repère 
indirect (let, d’autre part, qu'une rotation ne change pas la direction d’un 
repère. Et nous n'avons fait que des rotations. Comment expliquez-vous ce 
mystère ? (Question III.c.) 

Si vous avez réussi à répondre correctement à ces questions, bravo, vous 
êtes fin prêt à continuer. Sinon, amenez sur votre écran vos axes dans les 
mêmes configurations, progressivement. Et ne passez pas aux chapitres 
suivants sans avoir parfaitement compris les réponses ! 


(1) Un repère est indirect s’il n’est pas superposable à un repère direct. 
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REPONSES AUX QUESTIONS POSEES DANS CE CHAPITRE 


Question IIL.a 


La transformation consiste à changer le repère Oxyz en un repère 
OXYZ où OZ admet le vecteur N pour direction. Il faut pour cela exécuter 
une rotation d’angle y autour de Oz (matrice de droite). Après une 
symétrie qui intervertit les deux premiers nouveaux axes, on obtient un 
repère OX Yo Zo (action de la matrice centrale). Enfin on exécute une 
rotation d’angle 8 autour de OX, et l’on obtient le nouveau repère. 
L'ensemble est illustré par la Figure IL.A, Om étant confondu avec OY, et 
OM avec OZ. 


N.B.: N'oubliez pas que les transformations par les matrices sont 
effectuées en commençant par celle de droite. 


Question III.b 


Dans le cadre 2, E est confondu avec le plan xOz, normal à Oy; donc 
(p,g,r)=(0,1,0) et N=j. Cela est compatible avec les valeurs données 
car C, = =0ets; =s>=1. 


Question III.c 


Pour les deux autres cadres, les deux repères sont bien directs. Mais dans 
le cadre 3, l’axe Oz pointe vers le fond, alors que dans l’autre il pointe vers 
vous : des illusions d’optique et des inconvénients de la projection, n’est-ce 
pas. 


ET 


IV 
UN PLOT BALADEUR OU 
COMMENT TRACER N'IMPORTE 
QUOI DANS LE PLAN 





Avant de poursuivre notre prospection tridimensionnelle, nous allons, le temps 
d’un bref chapitre, revenir au simple plan, pour étudier un petit “truc” qui nous 
sera bien utile dans la suite. 

Il s’agit de ce que nous appellerons dans la suite le plot, du nom de l’instruction 
BASIC “PLOT” qui permet d’allumer un point lumineux sur l’écran. 


1. TRACE SUR UN PLAN PAR UN DEPLACEMENT DE PLOT 





En moyenne résolution (mode 1), votre Amstrad contrôle sur l’écran 
exactement 640 sur 100 points. Ces points sont appelés pixels. L’instruc- 
tion PLOT 4a,b,c permet d’allumer le pixel de coordonnées a,b dans la 
couleur c. En particulier, si c est la couleur du fond (paper), le pixel est en 
fait éteint: il disparaît. D'autre part, l'instruction test a,b permet de 
connaître la couleur du pixel de coordonnées a, b ; si cette couleur est celle 
du fond (0 en général), le pixel est éteint. 

Ces instructions vont nous être extrêmement utiles. En effet elles 
permettent, avec un peu d’habileté et un bon programme, de tracer à peu 
près n'importe quoi dans le plan, et la Figure IV.A en est un bon exemple. 


Ce dessin, comme tous ceux dont nous aurons besoin, est formé d’une 
succession de petits morceaux de droites. Son tracé correspond à 
l'allumage d’un certain nombre de pixels sur l’écran; pour l'obtenir, il 
suffit donc de donner à l’ordinateur l’ensemble des points qui doivent être 
allumés. 

Il va toutefois sans dire que, si l’on peut pour cela utiliser les 
coordonnées de ces points lorsque la figure est assez simple, ou lorsqu'elle 
est régie par une équation mathématique connue, il faudrait des heures et 
des heures de tâtonnements pénibles pour engendrer ainsi la tour Eiffel de 
la Figure IV.A, qui contient quelque 350 segments de droites. 

Nous allons donc utiliser un moyen beaucoup plus simple. Pour 
enregistrer un point, il suffit en effet d'amener, sur l’écran, un point mobile 
(le fameux plot baladeur) à l'endroit exact où l’on souhaite qu’un pixel soit 
allumé. 
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Pour déplacer commodément ce plot mobile, nous allons utiliser une 
manette de jeu ou, si vous n’en avez pas, le clavier (par exemple avec les 
touches fléchées). 

Cela est facile, avec l’aide de l'instruction INKEY que nous avons déjà 
utilisée au chapitre précédent (Programme IIL.2). 

Reportons-nous donc au Programme IV.1: nous reconnaissons nos 
INKEY aux lignes 80 et suivantes. 





14 ’ezpspsuasscasssssss-ascsesszssezss-ss=se-s==2ss=s=eszszs Plot baladeur 
24 MODE 1:INK G:1:BORDER 1:INK 1,24:PEN 1:INK 2,6 
38 DIM 36298,1) 
49 DEFINT h,isusvst 
59 ORIGIN -1,-1 
6@ KEY 141,"9oto SG@"+CHR#C13):KEY DEF 24,1;141 
78 PLOT 326,209,1:aC(4,1)=1:t=1 
8 WHILE INKEY(79)=-1 AND INKEYC583=-1 AND INKEYC743=-1 AND INKEY(C752=-1 
AND INKEYC72)=-1 AND INKEYC73)=-1 AND INKEYC682=-1 AND INKEYC77 )=-1: END 
9@ IF INKEYC6B2<>-1 THEN act,@)=-1:GOT0 599 
199 i=INKEYC740:IF i<>-1 THEN v=Qg'us-2-i/16:GOSUB 399 
119 i=INKEY(75):IF i<>-1 THEN vzdius 2+i/16:GOSUB 309 
129 i=INKEYC73):IF i<>-1 THEN uæÿivs-2-1/16: GOSUB 399 
139 i=INKEY(72):IF i<>-1 THEN usDivs 2+i/16:GO0SUB 309 
148 IF INKEYC793<>-1 THEN PLOT XPOS,YPOS,9: ta t-1:aCt,12=ABSC act, 122: 
DRAH act,@),act,12:PLOT act,9),act,1),1:GOT0 180 
159 IF INKEYC772C>-1 THEN act,92)=XPOS:act, 1)=YPOS:PLOT act-1,@),act-1,123,2: 
DRAH act,:@),act,1):tæt+1:PRINT CHR#C72:GÛTO 189 
169 IF INKEY(58)C>-1 THEN PLOT XPOS, YPOS,Z:act, 9)=XPOS act, 1 2=YPOS: 
act-1,1)=-act-1,1):tst+1: PRINT CHR#C7):GOTO 189 
17 IF t>199 THEN PRINT"StoP "END 
189 LOCATE 1,1:PRINT USING “###";t 
199 LOCATE 1,25:PRINT XPOS; :PRINT"/"YPOS; 
208 GOTO 88 
309 ‘=z===2=22cs=22s2e2u222-s2use2se2222222-s2s2s2==s22822= Placement du Point 
318 PLOT xXPOS,YPOS,h 
329 h=TEST(XPOS+u, YPOS+vy ) 
339 PLOT XPOS+u, YPOS+v, 1 
349 RETURN 
SO ’/===-2s2-ssersassss-sesssscsssac-sszas=essssssssezsezssansz Restitution 
519 CLS:MOVE 320,209 
529 signe=SGNCacD, 12) 
539 FOR t=1 TO 290 
ce. IF act.@)<G GOTO 580 
559 IF signe<Q THEN PLOT aCt,@),ABSCact,1));1 ELSE 
DRAH act,9),ABSCact, 122,1 
S69 signe=SGNCact, 12) 
579 MEXT 
589 PRINT CHR&7) 
599 WHILE INKEYC47)=-1 AND INKEYC77 2=-1 : WEND 
698 IF INKEYC(772<>-1 THEN tat-1:GOTO 85 
619 END 





Il y a en plus une petite subtilité : en posant ; = INKEY (x), on obtient 
i = 0 ou i = 32 selon que l’on a appuyé sur la touche de n° x sans, ou avec, la 
touche SHIFT ; les paramètres u et v sont alors, selon les cas, égaux à —-4, 
—2, 0, 2 ou 4. En outre, l’usage de la boucle WHILE-WEND fait que 
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l'ordinateur ne réagit qu’à certaines touches, ici les quatre directions de la 
manette (n° 72 à 75), la touche “e” (n° 58), la touche DEL (n° 79), la 
touche TAB (n° 68) et la touche “fire 1” de la manette (n° 77). 

Avant d'examiner de plus près ce programme, une petite explication est 
nécessaire. 


2. ENREGISTREMENT DU TRACE : POINT PAR POINT, SOMMET 
PAR SOMMET 





Avec notre plot, nous voulons enregistrer, c’est-à-dire conserver en 
mémoire un certain nombre de points de l’écran. 

Pour cela, il suffit de créer une matrice, simplement nommée “a” dans le 
Programme IV.1, à deux colonnes et avec un nombre N de lignes. A la 
ligne n, on enregistre le n°" point, en plaçant son abscisse (sa première 
coordonnée) x dans la première colonne (n° 0) et son ordonnée y dans la 
seconde colonne (n° 1): 


a(n,0)=x:a(n,1)=y 


Mais deux points de vue s’affrontent alors: 


e soit on enregistre tous les points par lesquels on fait passer le plot ; 

e soit on enregistre seulement certains points que l’on choisit soi-même, et 
l'ordinateur, lorsqu'il restitue le tracé, trace un segment entre chaque 
point enregistré. 


Dans le premier cas, l’opération ci-dessus décrite est faite automati- 
quement, vous n’avez donc pas à vous en préoccuper. 

Au contraire, dans le second, vous devez, chaque fois que vous 
souhaitez enregistrer un point, le signaler à la machine en appuyant sur une 
touche déterminée (par exemple la touche “e”, comme enregistrer, ou le 
fire de votre manette de jeu). 

Cette seconde méthode semble donc mauvaise et, de fait, elle l’est dans 
certains cas, en particulier si vous souhaitez dessiner à l’écran une forme 
assez complexe et tourmentée (par exemple un arbre) qui contient très peu 
de lignes droites. 


=.63;:= 


Dans tous les autres cas, et en particulier dans ceux qui nous 
préoccuperont par la suite, c’est au contraire la seconde méthode qui est la 
meilleure pour plusieurs raisons. 


Tout d’abord, la mémoire de votre ordinateur a beau être vaste, le 
nombre N de lignes de la matrice a est nécessairement fini, et par 
conséquent le nombre de points enregistrés aussi (on peut aller jusque vers 
3 000) ; il convient donc, surtout pour des dessins assez complexes comme 
la tour Eiffel, de se restreindre. Or, imaginez que vous ayez à enregistrer 
un simple carré de 40 pixels de côté. Le périmètre de ce carré étant de 
4 X 40 = 160 points, la première méthode enregistrera 160 points, mais la 
seconde seulement 4, car il n’y a que quatre sommets dans un carré ! De 
plus, si vous dotez votre dessin d’un grand cadre qui suit le pourtour de 
l’écran, la seconde méthode n’emploiera toujours que 4 points, mais la 
première quelque 2 X (640 + 200) = 1 680 points ! Vous voyez qu'il ne vous 
restera pas grand-chose de vos 3000 points possibles pour le dessin en 
lui-même ! 


Cela seul suffirait à faire choisir la seconde méthode, mais il y a en plus 
une seconde bonne raison. Examinez les segments de la tour Eiffel de la 
Figure IV.A : vous voyez que leur pente, c’est-à-dire leur inclinaison par 
rapport à l'horizontale, est très variable. Cela prouve que ce dessin a été 
obtenu avec la seconde méthode, car la première n’autorise qu’un petit 
nombre de pentes. En effet, puisqu'elle enregistre tous les déplacements 
de plot, et que le plot ne peut se déplacer que verticalement ou 
horizontalement (à la rigueur en oblique si vous appuyez sur deux touches 
à la fois), chaque petit segment ne peut qu'être orienté de même; un 
segment de pente quelconque devra donc être représenté de manière 
approximative par une succession de petites marches toutes égales, comme 
pour un escalier, ce qui n’est ni esthétique ni commode. Par contre, avec la 
seconde méthode, il suffit de placer le plot successivement aux deux 
extrémités du segment à tracer et d’enregistrer, en vous moquant 
totalement du chemin qu’il prend pour passer de l’un à l’autre. 


Peut-être comprenez-vous aussi maintenant pourquoi j'ai affirmé que la 
première méthode était quand même valable pour les dessins tourmentés : 
s’il y a très peu de segments de droites sur le dessin, les deux défauts 
disparaissent de facto. 


Dans la suite, nous utiliserons tout de même la seconde méthode, que 
vous maîtriserez facilement avec un peu d’habitude. 
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3. EXPLICATION DU PROGRAMME IV.1 : LEVER LE CRAYON 








A présent, le Programme IV.1 doit vous sembler plus clair : après avoir 
fixé les couleurs en 20 (le plot baladeur, couleur 1, sera jaune pour qu’on le 
distingue bien, le tracé des segments se fera en rouge), on dimensionne 
l’arrangement a pour qu’il puisse contenir 200 points (cela nous suffira 
dans la suite). La touche contenant le signe £, à côté de CLR, est réglée 
pour que vous puissiez revoir votre dessin par sa seule pression (ligne 60). 
Puis le plot est placé au centre de l’écran, et le compteur f est initialisé à 1. 
Ensuite, l’ordinateur attend que vous pressiez une touche (ligne 80). 

Si vous appuyez sur une touche de déplacement (par-exemple, la n° 72, 
aller vers le haut), alors le programme donne une certaine valeur aux 
paramètres u et v (ici 0 à u et 4 ou 2 à v) et passe en 300. Là, il remet le 
pixel où le plot se trouve à sa couleur initiale À (faute de quoi votre écran 
ne tarderait pas à se trouver envahi de petits points jaunes, et vous ne 
sauriez plus lequel est votre plot baladeur), puis enregistre avec TEST la 
nouvelle valeur de h, c’est-à-dire la couleur du pixel où l’on va placer le 
plot (lignes 320 puis 330), toujours en jaune. Vous constatez qu'avec u nul 
et y positif, comme dans notre exemple, le plot est bien légèrement déplacé 
vers le haut. 

Après l’exécution du sous-programme 200, le programme arrive à la 
ligne 170 (sauf si vous appuyez sur deux touches à la fois) où il vérifie que t 
ne dépasse pas la valeur maximale de dimensionnement de la matrice a, 
faute de quoi il arrête le programme. Ensuite, il affiche la valeur de t 
(ligne 180) et, en bas, les coordonnées du plot (cela servira dans 
d’autres chapitres). 

Puis il retourne en 80, attendant que vous appuyiez sur une touche. 

Si vous appuyez sur TAB (n° 68), le dessin est fini : il vous le restitue 
alors en 500. Si vous appuyez sur fire (n° 77), il enregistre le point où se 
trouve le plot, et trace un trait qui le relie au précédent (ligne 150). 

D'autre part, vous avez droit à l'erreur. Si vous appuyez sur DEL 
(n° 79), il décrémente de 1 le compteur f, et replace le plot à 
l'emplacement de l’avant-dernier point enregistré, non sans tracer une 
ligne noire sur le dernier segment rouge tracé (ne vous inquiétez pas si 
l'effacement n’est que partiel, c’est sans importance) ; ainsi, les prochains 
points enregistrés remplaceront ceux que vous aurez rejetés, à cause de la 
décrémentation de t. 
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Soit, mais à quoi sert la touche “e” (n° 58) ? Eh bien, c’est tout simple. 
Nous avons vu que, lorsqu'on enregistre un point avec la touche fire, un 
segment était tracé entre les deux derniers points enregistrés. Mais lorsque 
vous dessinez, il vous arrive de lever votre crayon : entre le nouveau point, 
où vous reposez votre crayon, et l’ancien, où la mine à quitté le papier, il 
n’y a pas de segment de tracé. Il faut que la machine vous permette de faire 
de même ; c’est le but de l’utilisation de cette touche e. Comme la touche 
fire, elle stocke dans le fichier les coordonnées du plot comme un nouveau 
point à retenir, mais elle ne trace aucun segment ; le point reste isolé tant 
que vous n'aurez pas réutilisé la touche fire. 

Mais un problème va se poser lors de la restitution du dessin ; en effet, 
comment le programme de restitution (lignes 500 et suivantes) saura-t-il s’il 
faut tracer un segment ou non ? 

Là encore, il faut enregistrer. L'idée qui vient naturellement à l’esprit est 
de rajouter à la matrice a une colonne remplie de flags : — 1 s’il faut tracer 
un segment jusqu’au point suivant, 1 sinon, par exemple. 

Seulement voilà, cela augmente de 50 pour 100 la place prise en 
mémoire par cette matrice ! 

Pour éviter ce qui pourrait devenir un désagrément, nous allons nous en 
tirer par une astuce, et laisser la ligne 30 en l’état. 

L’astuce se trouve en ligne 50, qui vous a peut-être intrigué. Le fait de 
placer l’origine des axes hors de l’écran fait que tous les points de l’écran 
ont des coordonnées de signe constant, ici strictement positives. Dès lors, 
le signe de ces coordonnées va nous servir de flag. Si le signe de la seconde 
coordonnée est négatif, et non positif comme il devrait l’être puisque les 
coordonnées du plot sont toujours positives, c’est que l’on a enregistré ce 
point avec la touche “e” (voyez en ligne 160 le changement de signe de 
a(t—1,1), donc il ne faut pas tracer de segment. Cela vous explique le test 
de la ligne 550 qui porte sur le signe de la seconde coordonnée du point 
précédent (c’est a(t — 1,1) dont on change le signe). C’est aussi pour cette 
raison que a (0,1) a été initialisé à une valeur strictement positive, sinon il 
serait nul, donc en 550 on tracerait un segment entre le premier point et 
l'origine. 

Résumons l'astuce : 


signe de a(t,1) positif: Tracer un segment jusqu’au point suivant. 


signe de a (ft, 1) négatif : Aller au point suivant sans tracer de segment. 
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Au fait, diront les puristes, pourquoi changer le signe de a(t—1,1) et 
non celui de a (t,1), ce qui permettrait d’utiliser le point n° 0? C’est bien 
entendu tout à fait possible, mais en fait cela ne simplifie nullement le 
programme, surtout au niveau de la restitution, car cela exige de faire 
revenir le plot en arrière. Le gain est donc, à mon avis, nul. Cela étant, il 
ne s’agit que d’un détail. 

A propos de détails, notez encore ceux-ci sur ce programme : 


e La même astuce est réutilisée sur la première coordonnée pour signifier 
au programme de restitution que le dessin est fini (voir lignes 90 et 
540). 

e Lorsque la restitution est finie, le programme se met en attente 
(ligne 590) ; si vous appuyez sur la barre (n° 47), tout s’achève en 610; 
si vous appuyez sur fire, le programme retourne en 80, vous permettant 
de reprendre votre dessin où vous l’aviez laissé. 


e J'ai trouvé plus commode qu’un bip sonore se fasse entendre à 
l'enregistrement de chaque point, d’où le PRINT CHRS(7) des 
lignes 150 et 160. 


e Lorsqu'un point est enregistré seul, il disparaît momentanément. Pour 
ne pas le perdre de vue, rajoutez l'instruction h = 1 en ligne 160. 


A présent, faites tourner le programme. Vous allez constater sur votre 
Amstrad quelque chose de curieux: les coordonnées de vos points 
augmentent de 2 en 2, même si vous avez tapé u = — 1 — 1/36, etc., en 
lignes 100 et suivantes. C’est qu’en moyenne résolution, le plot ne fait pas 
un pixel mais quatre. C’est pourquoi vous ne pourrez obtenir des 
coordonnées impaires. C’est aussi pourquoi le plot avance par multiples de 
2 ; le nombre de points parcourus ne s’en trouve pas réduit, mais le temps 
de déplacement est divisé par deux. 

Si toutefois vous trouvez le plot un peu lent dans ses déplacements, 
n'hésitez pas à utiliser la touche SHIFT, pour aller deux fois plus vite ; nous 
avons défini i pour cela. 


4. USAGE DES COULEURS 





Nous aurons besoin, dans les chapitres suivants, non seulement de ce 
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plot baladeur (alors n'oubliez surtout pas de conserver le Program- 
me IV.I), mais en plus de pouvoir l’utiliser en couleurs. 

En effet, jusqu’à présent, la couleur du dessin était uniforme. 
Maintenant cela ne sera plus le cas, si vous rajoutez au Programme IV.1 le 
supplément IV.1 bis. Vous pourrez ainsi changer la couleur du tracé (ou sa 
nuance si vous avez un moniteur monochrome : dans ce cas, choisissez les 
couleurs de telle sorte qu’on les distingue bien les unes des autres). 


PROGRAMME I,1 bis 





24 MODE 1:INK 8,1:BORDER 1:INK 1:24:PEN 1:INK 2,6:INK 3,18 

3@ DIM a(299,2) 

40 DEFINT h,i,u:vt,c 

7@ PLOT 329,206, 1:a(9,1)=1:t=1:c22 

80 WHILE INKEY(79)=-1 AND INKEY(52)=-1 AND INKEY(74)=-1 AND INKEY£752)=-1 
AND _INKEYC722=-1 AND INKEY(73)=-1 AND INKEYC682)=-1 AND INKEYC7722=-1 AND 
INKEY(C 62 )=-1 : END 

95 IF INKEY (622<>-1 GOTO 489 

150 IF INKEYC772<2>-1 THEN act, @2=xPOS : at, 1 2=YPOS:PLOT act-1,9),act-1,1),c: 
DRAH att,@);açt:1):act,ZDec't=t+l'PRINT CHR$C7):GOTO 188 

169 IF INKEYCS582<2>-1 THEN PLOT XF0S.YFOS,c:act,@2)=XPOS: act, 1 >= YPOS: act, 2)=c 
1aCt-1,12=-açt-1;:1):t=t+1: PRINT CHR#(7):GOTO 188 

400 ’=snassansansenzasasesez=zzzzz=u==cs2=scsussazszszs Chandement de couleur 
419 LOCATE 1,1:PRINT" k 

429 LOCATE 1,1:INPUT "Couleur";ic 

439 cec MODC 4) 

448 PLOT *xPOS,YPOS,c 

459 LOCATE 1,1:PRINT" ï 

469 GOTO 180 

559 IF siane<@ THEN PLOT act,9),ABSCact,123,act,29 ELSE 

DRAH act,82,ABSCact,122,act,2) 





Ce supplément IV.1 bis est assez clair, je pense : 


e En ligne 20, on choisit la troisième couleur (vert ici) en plus. 


e En ligne 30, on rajoute une colonne à la matrice, colonne qui contiendra 
le numéro de la couleur. Cette couleur, c, est initialisée au rouge, 
comme sur le Programme IV.1, en 70. 


e La touche C vous permettra d’aller au sous-programme de changement 
de couleur en 400 (lignes 80 et 95). Ce sous-programme affiche à 
l'emplacement du compteur t la question “Couleur ?”. Vous devez alors 
lui donner le numéro de la couleur que vous souhaitez utiliser. Cette 
valeur (comprise entre 0 et 3, d’où la ligne 430) restera fixe jusqu’à ce 
que vous réappuyiez sur la touche C. 


e Enfin, n'oublions pas que le tracé doit se faire dans la couleur que vous 
avez demandée, aussi bien lors du dessin que lors de la restitution, d’où 
le changement des lignes 150, 160, et 550. 
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J'ai déjà dit que nous nous servirions de ce programme, je vous propose 
donc de le conserver (mais séparément). Cela ne vous empêche pas, bien 
sûr, d’en profiter d’ici au chapitre suivant ; vous verrez que ses possibilités 
sont très étendues, et que l’on peut ainsi faire de très jolies choses! 
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V 
L'ART DE L'ILLUSION OÙ 
COMMENT REPRESENTER UN 
DESSIN SUR UN PLAN INCLINE 





Nous pénétrons à présent pour de bon dans l’univers des effets graphiques en 
trois dimensions, car il faut bien reconnaître que les trois axes du Chapitre III 
étaient assez innocents. 

Pourtant, c’est encore de plan que nous allons parler. Mais ce plan, nous allons à 
présent le considérer non comme un univers en soi, mais comme une partie de 
l'univers réel, de l’espace tridimensionnel. 


1. L'ILLUSION DE LA PERSPECTIVE 








Nous avons déjà vu au Chapitre III que la perspective dite cavalière, qui 
consiste en une simple projection, en fait n’était qu’une approximation des 
perspectives vraies, d’usage beaucoup plus complexe, que nous verrons au 
Chapitre X. 

Mais les figures qui illustrent ce chapitre sont là pour vous prouver que 
cette perspective a beau être approximative, elle n’en est pas moins très 
réaliste. 





Figure V.A 


Car la perspective est l’essence même de cet art de l'illusion qu’est le 
dessin sous toutes ses formes ; devant elle, on a du mal à considérer le 
dessin tel qu'il est, c’est-à-dire plan, et l’on cède à l'illusion de la 
profondeur. 

Cela ne facilite pas toujours le travail du dessinateur, car toute 
inexactitude dans la perspective risque d’être vite perçue. C’est pourquoi il 
serait risqué, et de plus difficile, d’obtenir des images semblables à celles 
de ce chapitre, directement à l’aide du plot baladeur du Chapitre IV. Peu 
importe, la machine est là pour faire le travail à notre place. Là encore, il 
suffit d’avoir la bonne idée. 

Réfléchissons.. Que voulons-nous faire ? 

Avant de passer à la représentation de volumes, nous voulons essayer de 
représenter dans l’espace un objet plan, non pas situé sur un plan parallèle 
à l'écran mais sur n’importe quel plan, même incliné. 
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Il s’agit donc, en fait, de passer d’un plan P (celui à dessiner) à un autre 
plan E (l'écran), via l’espace tridimensionnel. 

Eh bien, nous savons déjà le faire. 

En effet, soit un point (a, b) de P. Suivant la position de P dans un repère 
R qui est fixe par rapport à lui (alors que le repère R, que nous avons 
utilisé jusqu’à présent est fixe par rapport à l'écran E), il correspond au 
point (a,b), un point de l’espace de coordonnées (X,Y,Z) dans le 
repère R, et (x,y,z) dans Ro. 

Or, on peut choisir R comme on le veut, pourvu qu'il soit fixe par 
rapport à P. Nous le choisissons simplement, par exemple de telle sorte 
que P soit égal au plan XAZ (A étant l’origine de R). Dès lors, X = a, 
Y=0,Z=b. Donc, au point (a,b) on fait correspondre dans l’espace le 
point (a,0,b); c’est le contraire d’une projection. 

Maintenant on veut trouver (x,y,z). Cela est tout simple, si l’on 
considère que les deux repères se déduisent l’un de l’autre par une rotation 
d’angle ou d’axe donné. Ici, nous allons considérer que l’on passe de l’un à 
l’autre par la rotation dont la matrice M a déjà été donnée au 
Chapitre III.3, Paragraphe 3. On applique donc cette matrice au triplet 
(a,0,b), et l’on obtient le triplet (x,y,z). Enfin, l’on se souvient que 
l'écran E est parallèle au plan xOy du repère R; la projection de (x, y,z) 
sur E a pour coordonnées (x, y) ; il est donc inutile de calculer z. 

Nous sommes ainsi passés du doublet (a, b) de P au doublet (x,y) de E; 
c'était ce que nous voulions. 


Tout cela est bien plus facile à mettre en œuvre qu’à expliquer. Le 
Programme V.1 l’exécute en deux lignes (1030 et 1040). Le lecteur attentif 
y reconnaîtra les coefficients de la matrice M (mais seulement 4 sur 9, car 
Y=0 et l’on ne calcule pas z). 

Avant de taper ce programme, il faut aller chercher les précédents. 
Tapez: 


LOAD"“ Programme II1.2” Sur ce programme changez “dessin” en 
1000 (5 corrections à faire). 
RENUM 2000 L'ordinateur vous signale qu’il ne 


connaît pas la ligne 1000, marquée 
5 fois. C’est normal. 


MERGE “Programme IV.1” Pour rajouter ce programme au 
précédent. 
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A présent, tapez les onze lignes du Programme V.1. 


FROGRAMME "1 





619 ORIGIN 329,204:DEG:t@=t-1 

629 GOTO 2908 

1000 ’=szzerses=ssczz-assas2as-as2meszxe=acrsuzszz=sze Dessin du Plan incline 
1919 CLS:si9ne=SGNC ac, 13) 

1828 FOR t=1 TO t@ 

1939 xæSINCPsi)XCact,0)-320)/1.8 

1948 3=(-COSCP si 24CO0SCtheta kC ait, 92-320 )+SINCtheta >kCABSC act, 1))-200)3/1.8 
1958 IF siSne<O THEN PLOT x,5,1 ELSE DRAW x,w,1 

1969 =i9ne=SGNCact, 12) 

1978 NEXT 

198@ PRINT CHR#&(7) 

1399 GOTO 2159 





Il ne vous reste qu’à faire tourner le programme. Le début se présente 
comme celui du plot baladeur ; de fait, tout sera exactement semblable 
jusqu’au moment où, après la restitution, le dessin fini, vous appuierez sur 
la barre d’espacement. La machine enregistre alors la valeur maximale 10 
du compteur ft (cela évitera bien des tests), se place en degrés et recentre 
l’origine avant de vous envoyer en 2000 (lignes 610, 620), c’est-à-dire sur le 
Programme IIL.2 que nous avons déjà utilisé. 

Je ne détaille pas la suite : en dehors du calcul de x et y dont nous avons 
déjà parlé, les lignes 1000 et suivantes sont très proches des lignes 500 et 
suivantes du Programme IV.1 pour une raison évidente mais fonda- 
mentale : un segment est toujours transformé en un autre segment par des 
rotations et des projections, et au total cela se traduit tout de même par un 
DRAVW. 

Le mieux est, de toute façon, comme toujours, que vous essayiez afin de 
vous rendre compte par vous-même. Je ne vous donnerai qu’un petit 
conseil: mettez un cadre rectangulaire autour de vos dessins, cela 
augmente l'illusion. 

Notez également que rien ne vous empêche de taper MERGE 
“Programme IV.1 bis”, et de corriger la ligne 1050 en remplaçant les 1 par 
des a (t,2), pour obtenir des dessins en couleurs. 

Enfin, la division par 1,8 des valeurs naturelles de x et y est faite pour 
éviter que votre dessin déborde de l’écran quand il est en oblique. Mais si 
votre dessin est petit, supprimez-la, sinon vous ne verriez plus grand- 
chose. 


ST 





2. RECTO VERSO 





Le jeu de cartes lancé en l’air de la Figure V.B prouve que notre 
Programme V.1 (uni aux autres) peut déjà être utile dans des jeux. Nous 
en verrons aussi des applications plus “sérieuses” lors des chapitres 
suivants. 





Figure V.B 


Cependant, si l’on veut réaliser une animation avec une carte, on ne 
saurait s’en tenir au seul Programme V.1 

En effet une carte a deux faces. Mais si vous avez essayé le 
Programme V.1, vous avez probablement constaté que, lorsqu'on 
“retourne” le plan P en le faisant suffisamment tourner, la seconde face est 
semblable à la première, vue dans un miroir. En quelque sorte, le 
programme considère que vous avez dessiné sur une sorte de plaque 
transparente que l’on verrait alors de dos, et non sur une feuille de papier 
sur les deux faces de laquelle on peut faire des dessins différents. 
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Le Programme V.1 bis, greffé sur le précédent, vous permettra 
d’engendrer cet effet de recto verso. 


FROGRAMME 4,1 bis 





5 DIN a(4@@.1):uG=9:GOSUB 19:t9=t-1:u4=200:GOSUB 19:tizt-1:0ORIGIN 329,290: 
DEG:GOTO 2999 

34 ? 

74 PLOT 329,200.1:açuû,1)=1:t=1+u9 

178 IF t-u4>199 THEN PRINT"Stop" : END 

529 si93ne=SGNCa(u@, 12) 

534 FOR t=i+ug TO 298+ug 

619 RETURN 

624 ? 

1995 s=SGNCSINCPS1)):IF s<9 THEN u9=298:v9ati ELSE uG=9:v/0=t9 
1914 CLS:sig9ne=SGNC au. 12) 

1928 FOR t=u9+1 TO va 

1945 x=s#x:5=s3%49 
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Ce programme est peu compliqué. En 5, on envoie deux fois de suite sur 
le plot baladeur, transformé en sous-programme appelé par GOSUB : la 
première fois pour le recto, la seconde pour le verso. Les deux dessins sont 
enregistrés à la suite l’un de l’autre dans la matrice a dont la capacité a été 
doublée à cet effet, le premier à partir de 0, le second à partir de 200. 
N'oubliez pas d'éliminer la ligne 30, sinon vous verrez s’afficher “Array 
already dimensionned in 30”. On retrouve aussi en ligne 5 les ordres de la 
ligne 620 qui a été éliminée. Bien entendu, on procède à quelques 
réajustements dans la boucle (70 à 610), très clairs, je pense. Reste à 
comprendre comment l'ordinateur va savoir de quel côté du plan on se 
trouve, afin de déterminer s’il doit afficher le recto ou le verso. 

Pour cela, vous remarquerez (essayez) que lorsque psi est multiple de pi, 
c’est-à-dire lorsque sin (psi) = 0, l’on voit le plan P par la tranche ; on est 
alors à la limite entre le recto et le verso. De fait, si vous êtes familiarisé 
avec les sinus, sachant que P = xOz, vous vérifierez sur la Figure II.A que, 
lorsque le sinus de psi change de signe, on passe du recto au verso, ou 
l'inverse. 

Dès lors s, le signe de sin(psi), sert d’indicateur. On a décidé 
arbitrairement ici que lorsqu'il était négatif on était au verso, et sinon au 
recto, d’où les lignes 1005 et 1020. 

Encore une remarque sur la ligne 1045. Elle correspond à une symétrie 
centrale du verso. Si vous ne la mettez pas, vous verrez votre verso comme 
dans un miroir, comme pour le Programme V.1 quand on est du mauvais 
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côté du plan (et il n’y a pas de raison que cela change). En fait, ici votre 
dessin sera redevenu normal mais il sera tête-bêche par rapport au recto. 
En effet, le seul vrai moyen pour avoir un recto et un verso ordonnés 
comme sur une feuille de papier sans se forcer à faire un dessin à l’envers, 
est de faire, pour t supérieur à 200, a (r,0) = 320 — a(r,0), c’est-à-dire une 
symétrie dans P autour de la droite centrale. Cependant une telle 
opération, au demeurant tout à fait faisable (mais supprimez alors la 
ligne 1045), vous obligera à faire du calcul mental si vous souhaitez mettre 
un cadre autour de vos dessins comme pour les cartes, afin que les deux 
cadres soient bien ajustés. 

C’est pourquoi je n’ai pas donné le programme sous cette forme, car cela 
le complique, et bien souvent pour rien. Ainsi, pour mes cartes à jouer, 
peu m'importe que le verso soit tête-bêche : il est symétrique. 

Et maintenant, tout se complique. 
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VI 
LES POLYEDRES SOUS TOUS 
LES ANGLES 





Nous sommes déjà à plein dans l’espace, mais les objets que nous avons jusqu’à 
présent cherché à y représenter n'étaient pas encore à proprement parler 
tridimensionnels, en ce sens qu’ils pouvaient tous être contenus dans un plan. 

Toujours avec la volonté d'augmenter progressivement la difficulté, nous allons à 
présent nous attaquer à de véritables objets tridimensionnels, des objets que, 
même en poussant fort, nul ne peut faire rentrer dans un plan, mais tout d’abord 
aux plus simples de ces objets, à mon sens, à savoir les polyèdres, et en particulier 
les polyèdres convexes. 


1. QU'EST-CE QU’UN POLYEDRE ? 


Question évidemment essentielle si l’on souhaite savoir de quoi l’on 
parle. Je ne me permettrais pas de douter que mon aimable lecteur sache 
de quoi il en retourne, mais afin d'éviter toute erreur, mieux vaut se 
montrer précis sur une chose aussi capitale. 

Donc, définissons. Un polyèdre est tout d’abord un solide. Par là, 
entendons notamment qu’il est compact, c’est-à-dire surtout borné (aucune 
de ses dimensions n’est infinie) et accessoirement fermé (si on le considère 
comme creux, il n’y a pas de trou dans ses parois), et de plus connexe, 
c’est-à-dire en un seul morceau (une pomme et une poire font deux solides, 
pas un seul). Tout cela peut paraître évident mais ce n’est pas une raison 
pour le passer sous silence. Un polyèdre est donc un solide, mais de plus, 
limité de toutes parts par des plans. Sa surface extérieure est une succession 
de morceaux de plans, que l’on appelle faces. De ces définitions il résulte 
que ces faces sont elles-mêmes des polygones, c’est-à-dire des lignes brisées 
refermées sur elles-mêmes. Chaque pliure de ces lignes brisées porte le 
nom de sommet, et entre deux sommets, on a éventuellement une arête. 

Voici donc définis les polyèdres. Reste à savoir à quoi ils peuvent bien 
servir. Notons au préalable que nous connaissons déjà de nombreux 
polyèdres : un dé (un cube) est un polyèdre, les pyramides en sont aussi, et 
les diamants de bijouterie sont aussi taillés en polyèdre. En outre, il existe 
de nombreux objets qui sont peu différents de polyèdres, et ainsi 
pourrons-nous étendre notre champ d’action à des maisonnettes, des 
meubles, des chars, … 
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Figure VI.A 


Enfin, nous verrons au chapitre suivant que la théorie des polyèdres, 
combinée à celle des surfaces polynomiales, permet de concevoir à peu 
près n’importe quelle forme avec une excellente approximation. C’est là 
d’ailleurs le principe de base de la C.A.O. (Conception Assistée par 
Ordinateur). 

Mais, avant d’y rêver, revenons plus prosaïquement à nos polyèdres. 


2. DEFINITION DU POLYEDRE : SOMMETS, FACES ET ARETES 


Se ee ne ue QD DO NET D RG ESP ERSE 








Nous avons vu qu’un plan peut être défini par une équation ou par son 
vecteur normal, indifféremment. Pour le polyèdre, le même problème de 
la nature de la définition se repose. J’insiste tout d’abord sur l'importance 
capitale de ce problème. N'oublions pas que l’objet même de l’informa- 
tique est de traduire dans le langage spécial de la machine des choses 
parfois très simples pour nous, mais qui ne le sont en fait que parce qu'elles 
sont exprimées dans un langage courant, sans signification pour l'appareil. 
De fait, ce problème de définition ou de modélisation est, de loin, le 
problème majeur de la technique informatique. 

Ainsi, vous avez certainement compris, éventuellement à l’aide de la 
page précédente, d’un exemple ou d’un dictionnaire, ce qu'est un 
polyèdre. D'ailleurs, nous n'utiliserons guère que le cube comme 
illustration de ce paragraphe, un cube comme celui de la Figure VI.B. 
Mais votre Amstrad, qui sommeille paisiblement sur votre table, n’en sait 
rien encore. Comment lui faire comprendre ? Sûrement pas avec les 
phrases alambiquées du dictionnaire. 
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Schéma a. 


Schéma c. 
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Schéma d. Schéma e. 


Figure VI.B.a,b,c,d,e. 
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Schéma f. 


Figure VI.B.f. 


s 


Reportons-nous à la Figure VI.B et à ses schémas successifs. Le 
schéma a donne l’objet à représenter : le cube ABCDEFGH|, ici dessiné 
en perspective avec point de fuite (perspective réelle). Pour définir ce 
cube, l’idée qui vient naturellement à l'esprit est de lui donner les 
coordonnées de ses huit sommets en choisissant un repère, comme sur le 
schéma b, où A est (0,1,1), B(1,1,1), etc., puis de demander à l’appareil 
de tracer les arêtes. Le schéma c vient immédiatement vous informer que 
cette idée n’est pas la bonne, ou plutôt qu’elle est insuffisante. On a ici 
dessiné un polyèdre qui admet aussi ABCDEFGH comme sommets, et qui 
n’est pas un cube mais une sorte d'assemblage de deux prismes. Mais, me 
direz-vous, je vois bien que ce polyèdre n’est pas le bon, car il a deux 
sommets supplémentaires, I et J. Soit, vous le savez, mais l’ordinateur, lui, 
ne le sait pas, et allez donc lui expliquer ce qu'est un sommet. 

Nous saurons d’ici peu la différence essentielle entre ces deux polyèdres : 
le premier est convexe, le second ne l’est pas. Or il n’y a qu’un seul 
polyèdre convexe qui passe par nos huit points. Cette propriété nous sera 
utile, mais pas pour le moment car je n’ai pas encore l'intention de me 
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limiter aux polyèdres convexes. J'aurais très bien pu décider de tracer le 
polyèdre du schéma c au lieu du cube, et dans ce cas, les points seuls ne 
sauraient suffire. D'ailleurs c’est très simple : seuls les tétraèdres (à quatre 
sommets) peuvent être définis par la donnée de leurs seuls sommets ; ce, 
pour la bonne raison que deux sommets quelconques d’un tétraèdre sont 
toujours reliés entre eux par une arête. Ce n’est déjà plus vrai pour un 
polyèdre à cinq sommets. 

A la donnée des sommets, il faut donc nécessairement ajouter au moins 
un renseignement supplémentaire. 

Le tableau d est un renseignement supplémentaire possible, on donne ici 
à l’ordinateur les arêtes à tracer. Elles sont numérotées (arbitrairement) de 
1 à 12. On voit alors quelle serait la démarche à suivre : dans un premier 
temps, une matrice (mettons SOM) serait dimensionnée à s — 1 lignes et 
2 colonnes (s désigne le nombre de sommets, donc ici 8). SOM (u, v) serait 
la v + 1° coordonnée du u + 1° point (n'oubliez jamais que les matrices 
contiennent des lignes 0). Ainsi SOM (0, 0) serait la première coordonnée 
du premier point (le point A), c’est-à-dire 0, etc. Puis une seconde matrice 
(mettons AR), dimensionnée à s — 1 lignes et autant de colonnes, comme 
le tableau d, serait remplie de flags: AR (u,v) =0 si les points u — 1 et 
v — 1 ne sont pas reliés par une arête, 1 dans le cas contraire. Ainsi, ici on 
aurait AR (3,4) =0 (Det E non reliés), mais AR(4,5)=1 (E et F reliés). 
Le reste s’en déduirait par des tests. Autre possibilité, plus simple : AR est 
dimensionné à (a—1,1) (a =nombre d’arêtes = 12 ici). Chaque ligne 
contient une paire de points, extrémités d’une même arête. Par exemple, 
AR (0,0) = 0 (numéro de A) et AR (0, 1) = 1 (numéro de B) représentent 
la première arête, AB. Cela permet d'économiser de la place mémoire, et 
du temps d’exécution (en évitant les tests), mais je trouve cette seconde 
possibilité un peu plus pénible à utiliser ; cela ne l’empêche pas d’être la 
meilleure. 

Je n’utiliserai pourtant pas cette méthode dans ce chapitre, pour 
plusieurs raisons. Primo, elle est suffisamment simple à mettre en œuvre 
pour que vous puissiez vous passer de moi, même si vous êtes débutant ; la 
seule partie “difficile” est la projection, mais elle sera de toute façon 
exposée. Secundo, nous l’utiliserons un peu plus loin, sous une forme 
légèrement différente. Tertio, malgré sa simplicité, elle est encore trop 
compliquée dans certains cas. Quarto, elle est totalement inadaptée au 
problème épineux de la gestion des faces cachées. 

C’est précisément en vue de ce problème que nous allons utiliser une 
méthode différente et plus complexe. 
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Il s’agit d’une méthode basée sur les faces d’un polyèdre. Pour mieux 
voir ces faces, le schéma f représente le cube “éclaté”, c’est-à-dire coupé le 
long de certaines arêtes pour le rendre plan. Les six faces du cube sont 
alors numérotées (arbitrairement aussi). Le tableau e recense les points 
contenus dans chaque face, mais d’une manière un peu particulière. En 
effet, chaque face a ici quatre sommets. Or, si l’on enregistre la cinquième 
face, par exemple, dans l’ordre ABEF, et que l’on exécute le programme 
qui sera donné immédiatement, on obtiendra une aberration du type de 
celle du schéma c. Il faut donc enregistrer ABFE, pour avoir effectivement 
une face carrée. C’est ce que signifie le petit circuit qui figure sous le 
nombre 5 dans le tableau e. Ce circuit signifie également, outre qu'il faut 
prendre les sommets dans l’ordre des flèches, que le choix du premier 
sommet est arbitraire ; la face 5 est aussi bien FEAB ou BFEA que ABFE. 
En outre, je tiens à préciser tout de suite que si le sens de circulation n’est 
pas tout à fait arbitraire pour la gestion des faces cachées, le programme se 
chargera de rétablir le bon sens, donc vous pouvez aussi bien choisir AEFB 
que ABFE. 


Il existe, comme avec les arêtes, plusieurs moyens de mémoriser les 
faces de notre cube. Le moyen qui sera utilisé ici n’est sans doute pas le 
meilleur, quoiqu'il soit fort simple ; mais j’ai déjà dit que les programmes 
de ce chapitre sont élaborés en fonction du problème des faces cachées car, 
encore une fois, c’est sans cela le système par arêtes qui me semble le plus 
simple. 

Nous allons donc enregistrer notre polyèdre sous la forme d’une matrice, 
simplement dénommée a dans la suite. Cette matrice a trois dimensions. 
Soit f le nombre de faces du polyèdre, S le nombre maximal de sommets 
(ou d’arêtes) par face. Alors, a sera dimensionné en (f—1,S —1,2). Le 
nombre a(t,u,v) désignera la v“"® coordonnée (x pour v =0, etc.) du 
uime sommet de la °° face. Là encore, je devancerai les critiques : ce 
n’est pas le meilleur système, tant s’en faut. En particulier, chaque sommet 
devra être enregistré plusieurs fois puisqu'il appartient à plusieurs faces. 
Toutefois, cette méthode est en fait très commode pour certains polyèdres 
particuliers pour lesquels elle est d’une extraordinaire simplicité, et 
totalement inutilisable, j'en conviens, pour les autres ; je donnerai alors 
une autre méthode. 


En attendant, nous supposerons, dans le paragraphe suivant, que la 
matrice a (matrice des faces) a été constituée, d’une manière ou d’une 
autre. Rien ne vous empêche d’ailleurs de la constituer “à la main” pour le 
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cube par exemple. Cela aura le mérite de vous décourager à tout jamais de 
le refaire, et vous accueillerez ainsi avec joie les méthodes des paragraphes 
suivants. 


3. DESSIN ET DEPLACEMENT DU POLYEDRE 
(UTILISATION PAR LES FACES) 





Avant d'utiliser le Programme VI.1, exécutez les instructions suivantes : 


LOAD “Programmelll.1”.DELETE 400.RENUM 1050 


MERGE “Programmelll.2”.DELETE1350-1380, 2070, 2680, 2860 - 
Corrigez le mot “dessin” en 600 (dans les 5 lignes). 
MERGE “ProgrammeVI.1”. 


FROGSFRAMME WI. 1 





470 ‘’ssncscase-esap-sesme=scegmespeeceesssz-ecsassuezes Calcul de l’echelle 
473 INK 3,6 

459 FOR tzÿ TO f-1 

498 FOR u=8 TO AACt)-1 

598 ræaatt,u,@2%act.u,@D+act,u,12%acçt,u,12+act,u,23%kact;u,2) 

519 IF r > rmax THEN rmaxar 

529 HEXT:HEXT 

538 e=200/S0RCrmax ) 

549 thetaz45:Psiz4s 

ÉOÛ ‘'mmrzsmezeceseesszanessess=assas-ssesesessesssscseszs [race du Polyedre 
610 GOSUB 198 

620 FOR t=@ TO f-1 

625 FOR ueg TO AACt)-1 

649 x=a(t,u,8) 

638 y=act,u,1) 

669 zæact,u,2) 

678 GOSUB 1298 

659 IF u=g THEN a=XX:b=YY:PLOT a,b,1:GOTO 708 

698 DRAH XX,YY,1 

748 NEXT u 

719 DRAWH 3,b,1 

728 HEXT 

736 GOTO 2969 

1900 ’amsnaus-szsses-zcczs=az=cs==sszzzze Point de vue de Projection et axes 
1299 ‘’=z=z-z=essesssesssessecxc=asseszzzszzz Calcul des coordonees Projetees 
1214 XX=Cs1#x-c1xu ke 

1224 YY=Cs2#z-c1l#kc2#x-s 1Kkc2*y 2ke 

1234 RETURH 

1259 IF INKEYC383<>-1 GOTO 2788 ELSE GOTO 259@ 

2689 GOTO 349 

Z869 GOTO 39 

159009 ‘=====-2s=2ss2essz=2sse2cses=2sses-2ussesasss=z=2====22s2222 Verification 
15619 FOR t=0 TO f-1:FOR u=9 TO AACt)-1:FOR vsQ TO Z:PRINT act,u,VD:NEXT 
:NEXT:WHILE INKEY$="" : WEND : PRINT: PRINT :NEXT 

15624 END 





Quelques brèves explications sur ce Programme VI.1. Les lignes 470 et 
suivantes sont destinées à calculer le facteur d’échelle e. Ce facteur, calculé 
une fois pour toutes et réutilisé aux lignes 1210 et 1220 à chaque tracé, est 
calculé de telle manière que, quel que soit le polyèdre rentré au départ, il 
tiendra tout entier sur l’écran, et plus précisément dans un cercle de 
rayon 200 autour du centre de celui-ci. Les angles, d’autre part, sont 
initialisés en isométrique. 

Au sujet du tracé du polyèdre (lignes 600 et suivantes), notez tout 
d’abord la présence de la matrice AA que je n’ai pas encore mentionnée. 
Cette matrice, à une seule ligne de f éléments, contient tout simplement, 
pour chaque face, le nombre de sommets qu’elle comporte. Elle est 
destinée à raccourcir l’exécution du programme dans le cas d’un polyèdre 
où le nombre de sommets par face serait très variable. Dans le cas 
contraire, AA (f) peut être simplement remplacé par S, nombre maximal 
de sommets par face. D’autre part, l’utilisation des variables x, y,z et la 
séparation des lignes 1200 et suivantes du corps du programme sont de 
pure commodité (voir Chapitre X). Rien ne vous oblige à les conserver. 

Le reste du programme principal est assez clair. Notons que les 
lignes 680 et 710 sont nécessaires pour éviter les liaisons intempestives au 
changement de face et pour refermer les faces sur elles-mêmes. Pour ce qui 
est du calcul de XX et YY, nous retrouvons exactement le même calcul 
qu’au chapitre précédent. 

Quant aux lignes 15000 et suivantes, elles vous serviront à vérifier que 
votre matrice a est correcte. Permettez-moi d’avance de vous adresser mes 
plus sincères félicitations si vous réussissez à ne pas en avoir besoin ! 

Les autres lignes étant de simples liaisons internes du programme, il ne 
vous reste plus qu’à l’exécuter. Si vous ne voulez plus des axes, entrez la 
ligne : 


1095 RETURN 


et votre polyèdre sera seul sur l’écran. Pour ses déplacements, ils sont ceux 
du Chapitre III. 
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4. POLYEDRES CONVEXES ET CONCAVES. 


AVANTAGES, INCONVENIENTS 


Quoique le Paragraphe 5 du présent chapitre ne s’y limite pas 
totalement, je me vois obligé, pour la bonne compréhension de ce 
chapitre, de parler dès à présent des polyèdres convexes. 

Tout d’abord, il s’agit au préalable de les définir. On dit, d’une façon 
générale, qu’une partie de l’espace est convexe si, lorsqu'on y prend au 
hasard deux points a et b, le segment [ab] tout entier est contenu 
également dans la partie. Ce n’est là qu’une des nombreuses propriétés des 
parties convexes ; ces propriétés se retrouvent naturellement dans les 
polyèdres convexes, et même s’y multiplient. En particulier, notons que les 
faces des polyèdres convexes sont des polygones (comme pour tout 
polyèdre) également convexes (cette propriété est parfois également 
vérifiée par des polyèdres concaves, c’est-à-dire non convexes ; elle n’est 
donc pas suffisante). D’autre part, un polyèdre convexe est tout entier du 
même côté du plan d’une de ses faces, quelle qu’elle soit. 

Pour mieux faire comprendre la nature des objets convexes et leurs 
propriétés, nous allons utiliser un exemple, illustré par la Figure VI.C. En 
effet, s’il est facile d’expliquer la convexité pour des polygones (les 
polygones convexes n’ont pas d’angles rentrants), il est parfois difficile de 
repérer un polyèdre concave, et ce pourrait être une source d'erreur dans 
la suite, d’où la nécessité d’être clair. 





Figure VI.C 
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fe 
fc 





Figure VI.C, suite. 


Dans cette figure, j'ai choisi pour objet de mes explications deux 
polyèdres. Celui de droite à huit faces et six sommets : c’est un octaèdre. 
Chacune de ses faces est identique aux autres, et est un triangle équilatéral. 
On le dit pour cela régulier (c’est aussi le cas du cube). L'autre, à base 
pentagonale, sera appelé dans la suite PCC, c’est-à-dire Polyèdre 
ConCave. Car il est bien concave. Observez, en haut, le segment [ab] ou le 
segment [bc]. Il est clair que ces segments sont en dehors du PCC. Si 
celui-ci était en bois, on pourrait tendre entre les points b et c une corde à 
linge : elle ne toucherait pas les faces. 

Ce n’est pas le cas de l’octaèdre. En réfléchissant, vous verrez aisément 
qu'il n’est plus question ici de tendre une corde à linge, à moins de le faire 
creux. Ainsi le segment ab est entièrement inclus à l’intérieur, et il en serait 
de même de tout autre segment : au mieux serait-il dans une des faces, mais 
jamais à l'extérieur. 


_— 90 - 


Nous pouvons donc affirmer que l’octaèdre, lui, est convexe. 

Avant de vérifier que l’un possède les propriétés citées au début et 
l’autre pas, regardons la forme des faces de ces polyèdres. 

Pour l’octaèdre, c’est tout simple ; j'ai déjà dit en effet que ses faces 
étaient triangulaires. Elles sont donc convexes. 

Pour le PCC, il a (de haut en bas) : cinq faces triangulaires ; cinq faces en 
trapèze ; cinq faces rectangulaires ; encore cinq faces en trapèze ; une face 
pentagonale (la base). Ces faces sont donc toutes convexes. Nous voyons 
donc qu’un polyèdre peut avoir toutes ses faces convexes sans être convexe 
lui-même. Par contre, le polyèdre de la Figure VI.B, schéma c, a des faces 
non convexes comme AEIBF (sur cette face, l’angle EIF est rentrant). 
Cette remarque est à prendre en compte, comme nous le verrons sous peu. 


Par contre, j'ai dit qu’un polyèdre convexe était tout entier du même 
côté du plan d’une quelconque de ses faces. Cette propriété est suffisante, 
en ce sens que les polyèdres concaves ne la vérifient jamais. Ainsi, sur la 
Figure VI.C, au milieu, nous voyons qu’une partie seulement du PCC se 
trouve en avant du plan P, plan de la face «fc. Par contre, l’octaèdre est 
entièrement du même côté du plan P, plan de la face «By. Le lecteur 
vérifiera qu'il en est de même des sept autres faces. Pour le PCC, c'est 
plutôt le contraire, puisque seule la base vérifie cette propriété, toutes les 
autres faces sont des contre-exemples comme «B c. 


Arrivé à ce stade du paragraphe, vous avez certainement compris ce 
qu'est un polyèdre convexe, mais sans doute vous demandez-vous 
pourquoi je fais tant de cas de cette propriété à l’apparence bien innocente. 


Elle est en fait capitale pour la partie la plus difficile de ce chapitre, la 
gestion des parties cachées d’un polyèdre. Nous apprendrons en effet sous 
peu à ne faire dessiner à l'ordinateur que les faces visibles du polyèdre. Or, 
observons à présent le bas de la Figure VI.C. Nous constatons que, sur les 
vingt et une faces du PCC, douze sont visibles (fv), cinq sont cachées (fc), 
et surtout quatre sont partiellement visibles seulement. Ces quatre 
dernières faces ont été à nouveau représentées en vue éclatée, la partie 
hachurée représentant le morceau caché. 


Même travail à droite sur l’octaèdre. Que voyons-nous ? Quatre faces 
visibles, quatre cachées mais aucune qui ne soit que partiellement cachée. 
Ce n’est pas là le fruit du hasard, mais bien celui de la convexité. 

Dès lors, vous commencez à voir pourquoi j'ai tant insisté sur la 
définition par face des polyèdres d’une part, sur la convexité d’autre part. 


Grâce à cela, un seul paramètre nous permettra, pour une face donnée 
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d’un polyèdre convexe, de savoir si elle est visible ou non, suivant qu’il sera 
positif ou non. 


Peu importe pour l'instant la valeur de ce paramètre, nous le verrons 
plus loin. L’essentiel, ici, est de bien comprendre l'intérêt de la convexité. 
Imaginez votre Amstrad dessinant l’octaèdre. Avant de tracer chaque face 
de la manière vue précédemment, il fait un test et trace route la face si le 
résultat est positif, sinon il passe à la suivante. Au contraire, imaginez-le 
traçant le PCC. Que devra-t-il faire lorsqu'il aura à tracer l’une des faces 
qui n’est que partiellement visible ? Qu'il la trace entièrement ou qu’il la 
saute, le résultat sera mauvais. Il ne peut même pas tracer la partie visible 
en une seule fois, car celle-ci peut être formée de deux morceaux (voyez les 
faces de gauche), voire trois, ou bien plus sur des polyèdres concaves plus 
compliqués. On voit donc que chaque face devra alors être tracée point par 
point, et chaque point devra subir un test. 

La gestion des faces cachées sera alors bien plus complexe et aussi bien 
plus longue. Quelques trucs facilitant le travail seront donnés au 
Chapitre VII, mais j'espère avoir convaincu le lecteur de la commodité 
relative des polyèdres convexes. 


9. POLYEDRES A REPETITION CYLINDRIQUE 


Souvenez-vous du cube de la Figure VI.B. Si vous avez cherché à le 
définir sous la forme d’une matrice par face pour tester le 
Programme VI.1, vous avez dû rentrer pour cela ce que nous appellerons 
des paramètres, c’est-à-dire des indications chiffrées ou des équivalents 
(notamment des flags 1). Je vous propose de les compter. Tout d’abord, il 
y a huit sommets, chacun de trois coordonnées, soit vingt-quatre 
paramètres. Puis il y a six faces, chacune de quatre sommets, soit encore 
vingt-quatre paramètres. Ajoutons six flags pour l’orientation de chaque 
face, et nous arrivons à un total de cinquante-quatre paramètres, et c’est 
pourquoi vous avez dû vous amuser follement en le rentrant, si vous l’avez 
fait ! 

Les paragraphes suivants vont vous permettre de simplifier ce travail 
(après tout, l’ordinateur est fait pour cela.) dans un grand nombre de cas. 
Par exemple, celui-ci vous permettra d’obtenir le même cube avec six 
paramètres, soit. neuf fois moins! 


(1) On appelle flags des indicateurs équivalant à un bit, c’est-à-dire ne prenant que deux 
valeurs, 0 et 1, ou parfois — 1 et 1. 
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Expliquons comment ce “miracle” est possible. Vous avez certainement 
déjà ouvert un parapluie. Ce commode ustensile, une fois grand ouvert, 
peut être sommairement décrit ainsi : autour d’un axe principal, que nous 
appellerons Oz pour simplifier, une baleine, qui est une sorte de ligne 
brisée faite en fil de fer, est fixée. Un certain nombre de baleines 
exactement semblables sont également fixées tout autour, de la même 
façon, à des angles augmentant régulièrement à partir de la baleine de 
départ. Celle-ci n’est d’ailleurs distinguée qu'arbitrairement car, si le 
parapluie a par exemple six baleines, une rotation autour de l’axe Oz de 
360/6 = 60° ne changera rien à l’aspect du parapluie. 





Figure VI.D 
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Nous allons à présent nous transformer en fabricants de parapluies, mais 
de parapluies un peu bizarres. Observez la Figure VI.D. En haut, à 
gauche, j'ai dessiné une baleine : c’est une ligne brisée As A; A3 A3. L’axe 
Oz est indiqué, ainsi qu’un axe Or de coordonnées cylindriques (voir 
Figure II.A). Cette baleine est ici attachée par le bas à Oz, mais ce n’est 
nullement nécessaire. 

Puis cette baleine va être répétée six fois autour de l’axe Oz, l’axe Or 
(fictif) tournant à chaque fois de 60° autour de Oz, sa position initiale 
coïncidant avec Ox. Chaque point est alors répété six fois, A, devenant 
ainsi A0; Ao1; Ao2, etc., à l'exception toutefois de A; dont toutes les 
positions successives sont confondues, car ce point est placé sur Oz. On 
obtient alors un squelette représenté en bas de la figure. 

Mais sur tout parapluie qui se respecte, on tend une toile qui en assure la 
cohésion tout en donnant sa protection à celui qui s’abrite. Nous allons 
faire de même. Deux segments successifs, comme A5 3 A1 3 et Ao4 À: 4, 
vont constituer une face. Toutes les faces ainsi constituées, nous 
obtiendrons le polyèdre dessiné à droite, qui d’ailleurs évoque plus un 
diamant de bijouterie qu’un parapluie. 

Notez que ce diamant contient 19 faces, dont treize non triangu- 
laires. Pour le constituer directement, il aurait fallu quelque 
3X20+6+12X4+6X 3+ 13 = 145 paramètres, alôrs qu'ici il suffit des 
deux coordonnées de chacun des quatre points de la baleine, et du nombre 
de répétitions à exécuter, soit neuf paramètres seulement... et d’un bon 
programme, que nous allons exposer à l'instant. 

Il s’agit du Programme VI.2. Ce programme est destiné à être utilisé 
ajouté au Programme VI.1 (qui contient lui-même des programmes 
antérieurs, voir sa description), ainsi qu’avec les lignes de commencement 
que j'ai pris l'habitude de passer sous silence : mode, couleurs, etc., et ici 
un GOTO 3000 car c’est à cette ligne que tout commence. 

La partie du programme donnée ici (lignes 3000 et suivantes) est donc 
simplement destinée à engendrer de manière simple le polyèdre, son 
utilisation ultérieure relevant du Programme VI.I déjà vu, ou de tout autre 
programme qu'il vous plaira d'inventer, pour vos propres utilisations. 

Au vu de ce qui a été dit précédemment, et à l’aide de la Figure VID, 
les opérations à effectuer dans ce but peuvent paraître relativement 
simples. Il subsiste néanmoins quelques difficultés. 

La plus importante est posée par la forme des faces. La plupart de ces 


faces sont tétragonales, c’est-à-dire à quatre sommets. Ainsi de la face 


x 


A3 A1 3 À14A04 (tous les exemples qui suivent sont empruntés à la 
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Figure VI.D). Celle-ci, comme presque toutes, est formée de deux 
segments identiques, résultant d’un des segments de la baleine d’origine (le 
segment A, À, en l’occurrence), reliés entre eux par deux autres segments 
parallèles, soit au total quatre arêtes. 

Mais l’on voit sur la figure des exceptions. Notamment les six faces les 
plus basses du polyèdre sont triangulaires car, le point A; appartenant à 
l’axe Oz, il est invariant par les rotations que l’on fait subir à notre baleine 
autour de cet axe, et par conséquent A3 0 = A3; = A32 = … 

Pour résoudre ce premier problème, nous allons considérer que le 
point À n’est pas strictement sur l’axe Oz, mais qu'il en est tout près 
(r inférieur à 0,01). Dès lors, les six faces inférieures sont comme les 
autres tétragonales, mais avec deux de leurs sommets si proches l’un de 
l’autre que l’œil, et même l’écran, ne saurait les distinguer. Mais si l’œil ne 
sait pas faire la différence, la machine la fera bien, elle, et cette subtile 
différence lui permettra d’appliquer à ces faces les mêmes automatismes 
qu'aux autres, aussi bien pour leur création que pour leur tracé ou pour 
leurs vecteurs normaux (voir le paragraphe à ce sujet). 


Plus ardu est le problème posé par la face supérieure. En ettet, le point 
A9 n'étant pas sur Oz, notre baleine n’est pas attachée par les deux bouts à 
cet axe. Dès lors, à l’inverse du problème précédent, cet éloignement du 
premier point engendre une face supplémentaire, la face supérieure, qui a 
autant de sommets qu’il y a de répétitions, soit six dans le cas de figure. 

Cette (ou ces) face(s) supplémentaire(s) (car le dernier point peut lui 
aussi ne pas être sur Oz, dans d’autres cas de figure) peut être séparée des 
autres ; elle a en général plus de sommets, son vecteur normal est évident 
(troisième vecteur du repère, ou son opposé pour la face inférieure 
éventuelle), etc. 

Toutefois, pour des raisons de simplicité, ce n’est pas la solution choisie 
dans le Programme VI.2 qui incorpore cette face à la matrice globale des 
faces a. 


PROGRAMME 1.2 





3090 ’==2=nses=sanasssanzes2ses=2s=s==ez2 Polyedre a rePetition cylindrique 
3919 CLS:INPUT "Nombre d’aretes dans un Plan diametral ";k 

3029 CLS:INPUT "Nombre de rePetitions "in 

3030 f=nxkk 'DEG:'u=368/n 

3048 CLS:INPUT "Echelle d’affinite de x Par raPPort a z'";Ex 

3958 PRINT:INPUT "Echelle d’affinite de » Par raPPort a z";Ey 

3069 DIM bCk,1) 

3078 CLS:PRINT"ATTENTION!""Donnez les Points dans un Plan diametral" 
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3980 PRINT"'en les rePerant avec 2 coordonnees Cr,2z)" 
3890 PRINT"z allant en DECROISSANT.":FOR Teÿ TO 3G90:NEXT 
3199 CLS:PEN 3:PRINT"iere arete":PEN 1 
311@ PRINT"'ier Point" 

3120 INPUT "r=",bC9,8) 

3139 INPUT "z=",bC(B,1) 

3149 PRINT'"2eme Point" 

3158 INPUT "r=",bC1,@8) 

3168 INPUT "z=",b(1,1) 

3178 CLS 

3180 FOR y=2 TO k 

3199 PEN 3:PRINT y'"eme arete":PEN 1 

329G PRINT:PRINT'Le Premier Point est le deuxieme de ""l’arete Precedente." 
3219 PRINT"2eme Point" 

3229 INPUT "r=",bCy,0) 

3239 INPUT "z=",bCy,1) 

32248 NEXT 

325Q ff=f:smaxs3 

2269 IF bCG,G)=Q THEN b(0,8)=0.01 

327@ IF bCk,0)=Q THEN bék,92=9.081 

3289 IF b(@,0)>0.81 THEN f=f+1:smax=n-1 
3298 IF bCk,9)20.81 THEN f=f+i:smax=n-i 
3390 IF smax<3 THEN smax =3 

3319 DIM acf-1,smax,2) 

3320 FOR t=Q0 TO ff-1 

3336 i=INT(t/n):P=zt-ikn 

3348 ceEx%COSCP kw 2: s=EyX*SINCP#%u ) 

3354 a(t,9,2)=b(i,1) 

3369 att.@,4)=cxbc i,8) 

3379 a(t,8,12=s%xbC 1.0) 

33288 act,1,2)=b(i+1,1) 

3399 aft,1,@)=c#xbCi+1,0) 

3496 aft,1,1)=s%bCi+1,9) 

3414 c=ExXCOSCCP-1 kw): s=EYXSINCCP-1 Kw) 
3428 act,2,2)=bC1+1,1) 

3434 att,2,@)=c#xbci+1,@) 

3448 act,2,1)=s%bCi+1,0) 

3454 a(t,3,23=b(Ci,1) 

3469 act,3,@)=cxb( 1,0) 

3479 act,3,1)=s*xb( 1,9) 

348Q NEXT 

3499 DIM ARACF-1):FOR t=Q TO f-1:AACL)=4:NEXT 
3508 IF b(g,9»<=9.91 GOTO 3598 

3519 IF bCk,@3)<=9.01 THEN t=f-1 ELSE t=f-2 
3324 AACt)=n 

353@ FOR P=1 TO n 

3540 act,p-1,2)=b(0,1) 

3554 c=Ex*COSCCP-1)4w):s=EuXSINCCP-12#u) 
3564 act,Pp-1,@)=c#b(8,9) 

2579 act,P-1,1)=s*#bC0,0) 

3589 NEXT 

3599 IF b(k,@2<=0.01 GOTO 3678 

3698 AACF-1)=n 

3619 FOR P=1 TO n 

362@ acf-1,P-1,23=bCk,1) 

3634 c=Ex#COSCCP-12#u2):s=EuXSINCCP-1 2%) 
364@ aCf-1.P-1,8)=c#xbCk,9) 

3658 acf-1,P-1,1)=s#b0k,9) 


3 NEXT 
3678 GOTO 1398 





Passons dès à présent à ce programme. Il débute par quatre INPUT, qui 
engendrent quatre nombres, n,k,Ex et Ey. “k” est le nombre d’arêtes de 
la baleine. Ce nombre permet de dimensionner correctement la matrice b 
des points de la baleine. “n” est le nombre de répétitions, six dans le cas de 


06. = 


figure (où k valait trois, soit dit en passant). “Ex” et “Ey” sont des échelles 
d’affinité ®), L'introduction de ces nombres permet d’étendre encore les 
possibilités de variation de ces polyèdres, en les écrasant un peu 
perpendiculairement à Ox (Ex inférieur à 1), ou à Oy, ou au contraire en 
les dilatant (Ex supérieur à 1)... Mais, en général, nous leur laisserons la 
valeur normale 1. 

On calcule ensuite (ligne 3030) le nombre f de faces du polyèdre, faces 
supérieures et inférieures non comptées, soit n * k, ainsi que l’angle de 
rotation élémentaire w = 360/n (en degrés), soit 60° sur l’exemple. 

La matrice b, je l’ai déjà dit, contient les k + 1 points de la baleine, qui 
ont chacun deux coordonnées (puisque la baleine est plane). 

Ensuite, une série de INPUT vous demandent, dans l’ordre, les 
coordonnées des susdits points. L'ordre en question est important, sinon 
vous risquez d'obtenir n’importe quoi. L'ordre suggéré est celui où z 
décroît, mais il n’est nullement obligatoire. 

Pour un résultat optimal au cours de l’exécution du programme, je vous 
conseille de tracer votre baleine d’abord sur le papier, comme je l’ai fait en 
haut de la Figure VI.D, afin d’éviter des erreurs ou des incohérences (du 
type : annoncer quatre arêtes et n’en faire que trois), qui vous feraient. 
accuser injustement mon programme ! 

Arrivé à la ligne 3250, le programme a avalé votre baleine avec ses 
arêtes. Reste à la digérer. Et tout d’abord, il s’attaque aux problèmes 
dont nous avons parlé. Notez que ce problème ne concerne que les faces 
inférieures et supérieures du polyèdre, et plus précisément les premier et 
dernier points de la baleine, dont il s’agit de savoir s’ils sont ou non sur 
l’axe Oz. 

Si l’un y est (cas du point A3), alors on le décale très légèrement 
(lignes 3260, 3261), comme décrit précédemment (la différence restera 
imperceptible). Dans le cas contraire, il faut créer une face supplémen- 
taire, qui, de plus, aura n sommets. Or 5%, Joue ici le rôle de S — 1, où S 
est le nombre maximal de sommets par face. En général, il y a 3+1 
sommets par face (faces normales tétragonales), d’où Sax = 3. Mais s’il 
faut rajouter une ou deux faces (supérieure et inférieure), comme à cause 
du point A5, Smax augmente et vaut n — 1 (sauf si n = 3, d’où la ligne 3300). 
On obtient donc ainsi les lignes 3260 à 3290. II ne reste plus qu’à 
dimensionner la matrice des faces a au nombre exact de faces, ayant au 
plus sax + 1 sommets de 2 + 1 = 3 coordonnées chacun (ligne 3310). 


(1) Une affinité est une application linéaire de matrice type : 


OOXx 
© m © 
© © 
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Reste à présent à engendrer cette matrice des faces, c’est-à-dire à la 
remplir. 

Les faces sont numérotées de 0 à ff— 1 (avec ff = n * k) par l'indice r. 
L'indice i, variant de 0 à k — 1, est le premier indice des deux points les 
plus hauts de la face (je parle ici des faces normales tétragonales comme 
A 3 A1 3 A1 4 A0 4). L'indice p, variant de 1 à n, est le deuxième indice des 
points de la face qui ont le plus gros deuxième indice. L’explication de ces 
deux indices par point est illustrée par la Figure VI.D. De ce fait, la face t 
est celle qui contient les quatre sommets d'indices (i,p); (i+1,p); 
G+1,p—1);(i,p — 1), et dans cet ordre. 

Les trois indices sont liés par les formules de la ligne 3330. Sachant que 
le point d'indice (i, p) se déduit du point n° à de la baleine par une rotation 
autour de Oz d’angle p * w, et au vu des formules de rotation données au 
Chapitre II, tout à présent doit être à peu près clair jusqu’à la ligne 3480. 
En 3490, on dimensionne la matrice AA (qui donne le nombre de sommets 
contenus dans chaque face). Presque toutes les faces ont quatre sommets, 
les faces triangulaires étant considérées comme tétragonales. 

Reste à engendrer, s’il y a lieu, la face inférieure et la face supérieure. 
Pour ces faces, AA (fr) vaut n (n sommets), et les sommets sont toutes les 
images d’un même point de départ de la baleine, soit le premier A, (c’est le 
cas de la figure), soit le dernier pour une éventuelle face inférieure. 

Le programme s’oriente ensuite vers les routines de calcul d’échelle, de 
dessin, etc., que nous avons déjà vues au Paragraphe 3. 

Je tiens à préciser que ce programme est très loin d’être optimal. Je n’ai 
néanmoins pas cherché à l’améliorer pour ne pas trop le compliquer (voyez 
déjà la longueur des explications). Mes lecteurs doués pourront peut-être 
simplifier l'enregistrement de la baleine à l’aide du plot baladeur, ou 
encore, notant que chaque arête est tracée deux fois, trouver le moyen de 
résoudre ce petit inconvénient. Comment ? (Question VI.a.) De plus, il est 
possible, pour gagner de la place mémoire, de séparer les faces 
tétragonales dans une matrice à part, etc. 

Je crois toutefois que le programme, même non optimisé, vous 
permettra de créer sans difficulté des polyèdres très variés, comme celui de 
la Figure VID (les coordonnées à porter y sont indiquées), comme la 
grosse sphère de la Figure VI.F, comme le tétraèdre et le PCC de la 
Figure VI.C, comme le cube (rentrer une seule arête verticale et n = 4) ou 
toute autre des multiples formes que votre imagination ou le hasard vous 
suggéreront.. Même un parapluie, pourquoi pas! 


_ 98 - 


6. POLYEDRE CONVEXE D’UNE FAMILLE DE POINTS 





Les mathématiques fourmillent de ces petits théorèmes qui n’ont en 
eux-mêmes guère d'utilité, mais auxquels on peut parfois trouver un usage 
commode. Celui, assez simple, qui suit peut servir comme on le verra. 

Soit A9 A1 A2. À, - 1, une famille de points de l’espace (?). Il existe une 
infinité de polyèdres qui contiennent cette famille (c’est-à-dire qui 
contiennent tous les points de la famille), et même une infinité de 
polyèdres convexes. Mais, parmi tous ces polyèdres convexes contenant la 
famille, il en existe un, et un seul, qui soit contenu dans tous les autres: 
c’est le polyèdre convexe minimal (PCM) de la famille. 

Cette propriété vous paraît peut-être évidente. Notez que toutefois elle 
est fausse pour les polyèdres concaves. 

Ce PCM a de nombreuses propriétés. Outre la convexité résultant de sa 
définition, on vérifie en particulier que tous les sommets SiS; .…. Ss _ , de 
ce polyèdre font partie de la famille (A;) ; la réciproque est fausse, un 
certain nombre de points de la famille pouvant très bien se trouver à 
l'intérieur du PCM, ou bien sur une face ou une arête (c’est le cas par 
exemple si trois des points de la famille sont alignés). Mais une chose est 
sûre : le nombre s de sommets du PCM est inférieur ou égal au nombre n 
de points de la famille. 

Le PCM d’une famille de points peut être entièrement engendré par 
ordinateur. L’avantage est grand, car cela évite d’avoir à donner les 
paramètres d’orientation des faces et de leur nature; vous donnez 
simplement les triplets de coordonnées de chaque sommet du polyèdre que 
vous voulez créer, et l’ordinateur fait le reste. L’inconvénient résultant est 
que le polyèdre obtenu est convexe ; si cela est un avantage du point de vue 
des parties cachées, comme je l’ai déjà dit, cela n’en est pas moins limitatif, 
et les polyèdres concaves ne peuvent être conçus par la méthode exposée 
ci-dessous. D'une façon générale, les polyèdres concaves sont pénibles à 
engendrer, pénibles à dessiner, pénibles à utiliser... mais nous aurons 
l’occasion d’en reparler dans un autre paragraphe. 

Comment donc engendrer ce polyèdre ? Cela n’est pas vraiment simple, 
car deux points quelconques n’appartiennent pas forcément à la même 
arête, ni même à une arête, ni trois points à la même face. 


(1) On appelle famille de points un ensemble de points numérotés dans un ordre plus ou 
moins arbitraire. 
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Pour engendrer un PCM, il faut avoir recours à un algorithme. Ce mot 
pompeux désigne tout simplement le fait de répéter une même opération 
sur un ensemble d’objets, jusqu’à épuisement du stock. Ici les objets sont 
les points et les faces qu'ils déterminent, jusqu’au moment où il n’y a plus 
de face à créer. 


Un algorithme est précédé d’une initialisation, ou amorce, et est suivi 
d’un arrêt, en général basé sur une condition. 

Tout cela sera plus clair sur un exemple. Nous voulons engendrer notre 
PCM en créant à partir de n points, de coordonnées connues, les faces de 
leur PCM. 


L’algorithme, on le verra dans un instant, permet d’obtenir une nouvelle 
face à partir d’une ancienne face. Pour pouvoir l'utiliser il faut donc 
connaître au moins une face, d’où la nécessité d’une initialisation 
consistant à rechercher une première face. 


Cette initialisation se déroule ainsi: on commence par rechercher les 
deux points de la famille qui ont la plus faible coordonnée x, par exemple. 
Appelons ces points À et B. Nous admettrons que le segment AB est 
obligatoirement une des arêtes du PCM. Dès lors, il existe un point C au 
moins tel que ABC forme une face. Nous ne nous intéressons en effet ici 
qu'aux faces triangulaires, toute face plus grande pouvant toujours être 
considérée comme la réunion de plusieurs faces triangulaires. Pour obtenir 
le point C, on se réfère à la définition de la convexité ; le PCM doit être 
tout entier du même côté de la face ABC. Dans les faits, cela se traduit 
ainsi : si N est le vecteur normal à la face ABC (nous verrons tout à l’heure 
comment l’obtenir), les produits scalaires N + MA doivent tous être positifs 
ou nuls. On prend donc un point C, on teste tous les produits scalaires 
après avoir calculé le vecteur normal à la face supposée ABC; si l’un 
d’entre eux est négatif, le point ne convient pas, il faut choisir un autre C 
(le mieux est de les essayer dans l’ordre x croissant), sinon on a enfin 
obtenu notre première face. 


C’est alors que l’algorithme entre en action. En effet, on pourrait 
continuer à déterminer toutes les faces comme la première, mais ce serait 
trop long car, en fait, c’est un peu une recherche “au petit bonheur” qui 
entraîne d'innombrables tests à chaque essai. et il peut y avoir beaucoup 
d'essais. 
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Or il y a plus simple. Supposons que nous ayons une face ABC, de 
vecteur normal N, (dont nous noterons nr, la norme, car il n’est pas 
nécessaire qu’il soit normé). L’arête AB appartient nécessairement à une 
autre face ABD. Il faut donc trouver le point D. Pour cela, admettons que 
nous hésitions entre deux points M et P (voir Figure VL.E, schéma a). Soit 
N, et N, les vecteurs perpendiculaires aux triangles ABM et ABP 
respectivement, orientés positivement (explication plus loin), et de plus 
normés obligatoirement. Soit aussi ps, et ps les produits scalaires de ces 
vecteurs avec No. On peut voir sur la figure que le point P est en dessous de 
M; c’est donc ce dernier point qui est le bon. Si à et F sont les angles 
séparant les vecteurs en question, on constate également sur la 
Figure VI.E.a que 4 <B. Or, cela est général ; nous admettrons que le 
point D recherché est tel que l’angle séparant le vecteur orthogonal à ABD 
de N, est le plus petit possible ; c’est par conséquent celui qui a le cosinus le 
plus grand. Or, le produit scalaire entre No et N,, par exemple, vu que N: 
est normé, vaut (voir Chapitre Il): ps =nocos(â). De même, 
PS2 = nocos (5). D'où, no étant positif (norme), 4<B est équivalent de 
PS1 > ps2. Le bon point D est donc celui qui est tel que le produit scalaire 
du vecteur normal à ABD avec N, est le plus grand. I suffit donc de calculer 
ces produits scalaires pour tous les points, hors A,B et C, et de choisir 
comme point D celui dont résulte le plus grand produit. On aura ainsi 
obtenu une nouvelle face ABD. Il n’y a plus alors qu’à rebaptiser cette 
nouvelle face ABC, et à recommencer l’algorithme au début. 

Notez que je n’ai cessé de parler du vecteur normal à une face du 
polyèdre. Or, on sait qu’il existe, à norme donnée, deux vecteurs 
perpendiculaires au plan P d’une face ABC: N et son opposé — N. Lequel 
est le bon ? (Voir Figure VL.E, schéma b.) Pour un polyèdre, on décide 
arbitrairement que le bon est celui qui sort du polyèdre, c’est-à-dire qui est 
orienté de l’intérieur à l’extérieur de la face. Le polyèdre étant convexe, si 
l’on se donne un point quelconque D du polyèdre n’appartenant pas à la 
face ABC, N doit pointer du côté opposé à D, et donc les vecteurs N et DA 
sont séparés par un angle aigu, donc leur produit scalaire est positif, alors 
que DA et —N sont séparés par un angle obtus, d’où un produit scalaire 
négatif. Si le produit scalaire est nul, D est dans P, il faut donc choisir un 
autre point de test. Ainsi, pour trouver N, on procède de la sorte: on 
calcule V = AB / AC (par exemple) ; on prend un point D de la famille, et 
on calcule ps = V - DA; si ps est nul, on recommence avec un autre 
point D; si ps est strictement positif, alors N=V, sinon N=—V. 
C.Q.F.D. 
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L’algorithme, naturellement, ne doit s’exécuter que si l’arête AB 
n'appartient encore à aucune des faces trouvées, autre que ABC. Dans le 
cas contraire, 1l faut exécuter un changement de nom des points, voire de 
face. Lorsque enfin il devient impossible de trouver une arête qui 
n’appartienne déjà à deux faces différentes, alors c’est l’arrêt : le polyèdre 
a été totalement engendré. 

Tout cela se trouve réuni dans le Programme VI.3 dont seul, toutefois, 
l’organigramme est donné. Le détail de ce programme ressemblerait en 
effet beaucoup à celui du Programme VI.4; en outre, un tel programme 
me paraît trop lent pour être utilisé en BASIC. C’est pourquoi le lecteur 
initié à d’autres langages plus rapides pourra, je pense sans grandes 
difficultés, exécuter un tel programme grâce à son organigramme. Les 
autres utiliseront le Programme VI.4, plus commode et de buts sem- 
blables. 


Le lecteur intéressé se reportera donc au susdit organigramme, sur 
lequel je ne donnerai pas de détails pour de semblables raisons. En 
particulier, de nombreuses parties de ce programme se retrouveront 
presque inchangées dans le Programme VI.4, qui sera expliqué en détail 
dans le paragraphe suivant. 

Un seul problème mérite d’être expliqué dès à présent. D'ailleurs, il ne 
sera pas repris ensuite, car il se reposera dans les mêmes termes. Avant de 
commencer à engendrer les faces, il faut dimensionner la matrice a qui les 
conserve. Or, pour cela, il faudrait connaître le nombre de faces du PCM à 
l’avance, en ne connaissant guère, en fait, que le nombre de ses sommets, 
et encore, car les n points initiaux ne sont pas forcément tous des 
sommets... C’est impossible. Cela peut toutefois s’arranger, si l’on peut 
trouver une majoration de f, c’est-à-dire un nombre F dont on est sûr qu’il 
soit supérieur à f. Or, on dispose de la formule suivante, valable pour tout 
polyèdre convexe ; s’il a f faces, s sommets et a arêtes, alors f+s = a +2. 

Mais a est inconnu, s aussi (on sait seulement que s<n). Mais vous 
pouvez constater que, si chaque face est triangulaire, il y a trois arêtes par 
face et, d’autre part, chaque arête appartient à deux faces. Donc 2a =3f, 
et il en résulte que f=2(s —2). Donc F=2(n—2) convient comme 
majoration. C.Q.F.D. 
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7. POLYEDRES “ETAGES” 


x x 


Nous allons à présent nous attaquer à un problème semblable au 
précédent, dans ses termes et dans son application, mais sensiblement 
différent dans son utilisation et dans ses résultats. 

Le nouveau système qui va suivre est basé sur une observation du 
précédent. Pour la fabrication du PCM, il faut d’abord donner les points à 
utiliser, avec leurs trois coordonnées, ce qui n’est guère commode. 

Il est infiniment plus simple d’utiliser le plot baladeur que de donner des 
ribambelles de nombres. Mais voilà, le plot ne peut être utilisé que dans un 
plan, et tous les sommets d’un polyèdre ne sauraient être contenus dans un 
plan. N'importe, ils sont contenus dans plusieurs plans. 

En effet, pour tout polyèdre, il est toujours possible de trouver une 
famille de plans T;, tels que tout sommet du polyèdre soit contenu dans 
l’un des T;, et de plus, tous parallèles entre eux et parallèles à un plan fixe 
donné arbitrairement, par exemple le plan xOy. Il suffit pour cela 
d'imaginer le polyèdre découpé en tranches comme un pain. 

Or, l'intersection d’un plan avec un polyèdre est un polygone (1). Dès 
lors, supposons qu’une famille de plans T;, d’équation z =z(i) où z (0), 
etc. sont des constantes données, étant déterminée, nous donnons dans 
chaque plan T,, à l’aide du plot baladeur, un polygone de g (i) + 1 sommets 
notés P(i,0), P(i,1), .…, P(i,q(i). Puis, nous pouvons relier ces 
polygones en constituant des faces, le résultat étant un polyèdre en 
quelque sorte constitué par étages, comme une maison, que l’on a aussi 
l’habitude de décrire par des plans parallèles ; en effet, un architecte donne 
bien, à l’ingénieur chargé de construire la maison, des plans, c’est-à-dire 
des sections successives de la maison, étage par étage, soit autant de plans 
(parallèles ici à l’horizontale) qu’il y a d’étages. C’est pourquoi les 
polyèdres que nous constituerons de la même façon seront appelés 
polyèdres étagés (PE). L'architecte donne aussi la hauteur de chaque étage, 
ce qui équivaut à donner sa hauteur par rapport au sol z(i). Que fait 
l'ingénieur ? Il relie les étages entre eux par des murs, jusqu’à obtention de 
la maison complète. Ici, vous êtes l’architecte, vous donnez les plans et les 
hauteurs. L'ordinateur est l'ingénieur, il construit le polyèdre en reliant 
chaque section à la suivante. 


(1) ou plusieurs éventuellement. Mais n’épiloguons pas. 
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En principe, tout polyèdre peut être ainsi obtenu. Il suffit pour cela de le 
découper correctement. Le résultat sera légèrement distinct du polyèdre 
de départ, car il y aura plus de faces et plus de sommets, les sommets des 
polygones de chaque section n’étant pas forcément tous des sommets du 
polyèdre de départ. Ainsi, une seule face du polyèdre initial pourra se 
retrouver découpée en morceaux (coplanaires évidemment) enregistrés 
sous la forme de faces distinctes (encore que cet inconvénient puisse en 
réalité être résolu ; comment, à votre avis?). (Question VI.b.) Mais la 
forme générale, qui est la plus importante, subsistera bien. 

En fait, pour des raisons techniques qui vont bientôt apparaître, il faut 
que les polygones des sections soient convexes (on pourrait choisir des 
concaves, mais il faudrait aider un peu l’appareil, comme on le verra plus 
loin). Cela limite le nombre de polyèdres possibles, mais les polyèdres 
obtenus ne seront pas nécessairement convexes. On les dira convexes par 
tranches (CPT). | 

Pourquoi donc convexes par tranches? C’est que, au cours de la 
génération du polyèdre, nous ne considérerons à la fois que deux plans T;, 
le plan T, et son successeur T, ; , (voir Figure VIE, schéma c). Les autres 
plans seront (momentanément) oubliés. Dès lors, si l’on considère les deux 
polygones Pg, et Pg, +, intersections du polyèdre à créer et des deux 
plans, il peuvent être considérés, à condition qu'ils soient convexes, 
comme deux des faces d’un polyèdre imaginaire PCX,, compris entre les 
deux plans, convexe, et admettant comme sommets les g (p) + 1 sommets 
de Pg,, et les g(p + 1) + 1 sommets de Pg, ; ,. Ce PCX, est, en fait, on 
l'aura compris, le PCM de ces points du Pg, et du Pg, ;, réunis, mais 
considérés seuls dans l’espace. Quant au vrai polyèdre, il sera en quelque 
sorte la réunion de tous les PCX; superposés, tout comme une maison est la 
réunion de tous ses étages superposés. 
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POLYÈDRES “ÉTAGES” (suite) 


FACES EXTRÊMES 











Go = q (0) 
gi=q({n) 
q = max (o,q1 


CALCUL DU 
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PROGRAMME WI. 4 





12 GOTO 5448 

349 REM 

345 IF fla9=1 GOTO 478 

499 FOR us=9 TO 2 

322 FOR t=9 TO 1:FO0R u=Q TO q 

324 r=fe(t,u,BDXfect,u,4)+fect,u,12*fett,u,12+fect u,22)#fect,u,2) 
526 IF r>rmax THEN rmaxer 

528 NEXT:NEXT 

635 FÜR ue TO 2 

738 IF 941=1 GOTO 814 

744 IF c2>=9 GOTO 818 

754 FOR u=9 TO qg 

768 x=fe(B,u,@):y=fe @,u,1):z=fe(B,u,2):GOSUR 1294 
779 IF u=@ THEN a=XX:b=YY:PLOT a b:GOTN 7939 

788 DRAW XX,YY 

799 NEXT u 

848 DRAW 3,h 

819 IF 92=1 GOTO 2948 

829 IF c2<=Q@ GOTO 2488 

339 FOR u=9 TO qi 

849 x=fe(1,u,B):yefec1l,u,1):z=fec1,u,2):GOSUB 1244 
850 IF u=g THEN a=XX:h=YY:PLOT 3,kh:GOT0 879 

368 DRAH XX, YY 

87@ NEXT u 

888 DRAH 3,b 

899 GOTO 2489 
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5909 
5919 
5929 
3938 


lRERSSRNeSRSS=SSSS2es2sssupsssesssessesres=escessecsezcssz Plans etades 
INPUT "Nombre de Plans etades";n:n=n-1 
CLS:DIM zCn):DIM 4Cn) 
INK Z,6:PEN 2:INK 3,18 
PRINT TAB(7)"Ordonnee des Plans etañes" 
1 


PEN 

PRINT:PRINT"(Par ordre CROISSANT obligatoirement )":PRINT 

FÜR t=Q TO n 

PRINT'"Ordonnee du Plan #"t+1;:INPUT zCt) 

NEXT 

CLS:DIM PCn:29,1) 

PRINT "A Present, donnez les intersections avec" "les Plans successifs 


grace au Plot""baladeur," 


5129 
5139 


PRINT"Il n’est Pas necessaire Que ces ""intersections soient fermees" 
PRINT “Mais elles doivent etre convexes," “"decrites dans le sens 


triSonometrique," 


5149 


PRINT "et leur Premier Point dans ce sens""anQulaire doit Preceder le 


Premier "Point de l'intersection Precedente." 


5159 


PEN 2:LOCATE 1,25:PRINT"APPuyez sur la barre Pour continuer": 


WHILE _INKEY(47 2=-1 : WEND 


5160 
5179 


ORIGIN 329,298 

FOR si TO n+1 

CLS: TAG 

PLOT 9,-290,3:DRAW Q,188:PRINT"'u"; 
PLOT -329,9:DRAW 349,9:PRINT"x"; 
TAGOFF 

y=3 

FOR P=9 TO 1-2 

GOSUB 12998 

DRAW PCP,9,@),PCP,8,1) 

DRAW PCP,1,M3,PCP,1,1) 

NEXT 

Pal-1 


gai 

PEN 3:LOCATE 25,1:PRINT"Plan numero"l 

GOSUE 19064 

NEXT 

DEFINT f:f=9 

FOR 1=9 TO n 

faf+4c1)+1 

NEXT 

f=2xf 
lERSCRSSRSSSSSSSSSSSSNSERERESESDEEESLESLESSESSSENEZENCSRSESNELSSSSSSSUEN 
uesxssseseszsese==sesz CENFRATION DU POLYEDRE szzsssussssosss-esasess 
, RSSSRSSSSSSLSSS SSL ES SSD RSSRE MESSE NEEENEMMEMMENLEMMMEMELCENMEENMENMENLE 


P=g'it=9 

DIM aCf-1,2,29:DIM nCf-1,2) 
lHesscsnesserezssss2ssssesescessss=esssss=2=zsez LIENS ENTRE DEUX PLANS 
lRRRSSRRRSSRSSRENSSL AS ASSLSSLSSESLSENSSESSESMSSSESSSSESS ASE SSSSSSE= FMOrCe 
b=-1 

b=b+1 

IF b=4CP+1) THEN PRINT'Erreur dans le Plan "P:END 

GOSUB 6540 

FOR k=1 TO 4CP) 

testi=nD#(PCP,k,@2-PCP,9,23>+n1xCPCP,k,12-PCP,8,12) 

IF test1>9 GOTO 6139 

NEXT 


39=P(P,9,00):a1=PCP,8,1):a2=zCPp):f9a=0 
bO=PCP+1,b+1,9):b1=PCP+1,b+1,1):b2=zCP+1):f9b=b+1 
cH=P(P+1,b,D):c1=PCP+1,h,13:c2=z(P+1):f9c=b 

ta=t 

n2=( 39-00 3#Cc1-b12-< 31-b1 24€ c9-h@ ) 

IF n@<>@ THEN n2=n2#SGN(xknD) ELSE n2=n2Z*xSGNCyXnl ) 
IF fSb=qCP+1) THEN fab=-1 

faba=fsb 

CLS:PEN 1:GOTO 7498 

lessssssszzzzzezs=2sz= Calcul du vecteur normal 
X=(ZCP+129-ZCP D2KCPCP+1,b,13-PCP+1,b+1,13) 
Y=CPCP+1,b+1,9)-PCP+1,b,@DD#CZCP+12-ZCP D) 

l=1 
test2=x#k(PCP+1,1+b+1,93-PCP+1,b+1,@3)+u#kCPCP4+1,1+b+1,12-PCP+1,b+1,12) 
IF test2=4 THEH 1=1+1:G0T0 6544 

IF test23Q THEN n9=-x:nl=-s ELSE nA=x:n1=4 

RETLIRH 
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Zzsss-sszssz2s-2=sas-ss-=s=ssez2==c=ssuz2ess flgorithme 
7419 NN9G=n@ :NHN1=n1 : NN2=n2 
742@ x=P(P1,f9a+1,G):u=p(P1,f9a+1,1):z=7zCP1) 

7434 GOSUB 7298 

7844 Psj=Ps :n@@=n@ :n11=n1 :n22=n2 

7959 x=r(r2,fab+1,4):y=PCP2,fab+1,1):z=zCP2) 

7864 GOSUB 7289 

7478 Ps2=Ps 

798Q IF Psi<Ps2 GOTO 7129 ELSE n#=n@Binl=n11:n2=n22 

7990 cO=añ:ci=al:c2=32:foc=f93 

719Q a9=b@:a1=b1:a2=b2:f93=f9b 

7119 bO=PCP1,f9c+1,@):b1=P(P1,fac+1,1):b2=c2:f9b=f9c+1:GOTO 7498 

7129 cA=b@:ci=b1l:c2=b2 : fac=f9b 

7134 bB=P(P2,fF9b+1,9):bi=PCP2,f9b+1,1):f9b=fab+1:GOTO 7498 

7290 ‘====22=2==22222222= calcul de Produit scalaire 

7219 n@=(b1-a12#(z-a2)-Ch2-a2)#Cy-21) 

7220 n1=(b2-a2 24 x-a9 )-Cb@-a9 x z-32) 

7230 n2=Cb9-30 )4Cy-a12)-Cbl-a12)4çx-38) 

724Q test3=nDk(c-a8 )+n1#Ccl-a1)+n2#(c2-a2) 

7250 IF test3>9 THEN n@=-n9:n1=-n1:n2=-n2 

7260 IF test3(>@ GOTO 7324 

7270 c=f9c 

7288 c=c-1:1F cæ-1 THEN ceq(p2) 

7299 test4=nDk(P(P2,c,D)-a9)+n1XCPCP2,c,1)-a1)+n2*Cc2-232) 

7300 IF test4=0 GOTO 7289 

7314 IF test4)>9 THEN n9=-nD:nls=-n1:n2=-n2 

7320 ren@#n8+n1%n1+n2*kn2:r=SORCr ) 

7339 Ps=nB*NN9+n1X*NN1+n2%NN2 

7349 IF r<>@ THEN Ps=Ps/r 

7350 RETURN 

736@ GOTO 7298 

7400 ’seszzssem=esasess2ec-essesses2ascass jteration 

741Q IF 32=ZzCP) THEN P1=P:P2=P+1 ELSE P1=P+1:P2=P 

7420 IF f9a=4(P1) THEN F93=-1 

7439 IF fSb=qCP2) THEN fab=-1 

7440 IF f9a=9 AND fob=fab@ AND P1=p AND t>1+t9 GOTO 7598 

7459 GOSUB 93908 

746Q GOTO 7298 

7500 ’sencezsessasesessemsess=sasces=sese==ee=ssses=assx Changement de Plans 
7519 P=P+1 

7520 IF P=n GOTO 6929 

7339 GOTO 6108 

SO0Q ’s=s2ss22ascas22z==ceas-=222=2es2e==es=2-=2es=2sssucss FIN,FACES EXTREMES 
8419 fat 

8929 49=4(8) 

8938 41=40n) 

8949 A=MAX(41,48):DIM fec1.4,2) 

8050 FOR u=@ TO qg 

8960 FOR v=Q TO 1 

3978 fe(B,u,v)æP(Q@,u,v) 

8988 NEXT:fe(g,u,22=zCB):NEXT 

8090 FOR u=9 TO 41 

819 FOR v=@ TO 1 

8119 fe(l,u;v)=PCn;u;v) 

8129 NEXT:fe(1,u,2)=zCn):NEXT 

8139 fla9=1 

814Q ERASE P 'ERASE 4 

8159 GOTO 1309 

9000 ’=snmecssmms-essee2essesesesesessse Enregistrement facetvecteur normal 
9010 act,0,0)=ag'act,@,1)=a1:act,@,2)=a2 

9929 act,1,9)=bBiact,1,13=bl:act,1,2)=b2 

9939 act,2,@)=c@:act,?2,13=cl:act,2,23=c2 

9949 n°t,9)2=n8inCt, 1)2=n1:nCt,2)=n2 

9950 te=t+1 

9968 RETURN 

10000 ’ssss=assancencescaseeszsses=ecescemsszesessssessasszz=s Plot baladeur 
19919 PLOT 9,8,y 

19929 t=9 

19039 WHILE INKEYC79)=-1 AND INKEYC38)=-1 AND INKEYC712=-1 AND INKEYC63)=-1 
AND INKEY(193=-1 AND INKEY(22)3=-1 AND INKEYC68)=-1 : WEND 

19849 IF INKEYC68%<>-1 THEN 9CP )=t-1:RETURN 

19959 IF INKEYC71)=ÿ THEN PLOT XPOS5-2,YPOS, y 

19969 IF INKEYC713=32 THEN PLOT XPOS-4,YPOS, 4 

19979 IF INKEYC71)=128 THEN PLOT XPOS-1,YPOS, y 

19989 IF INKEY(71)=162 THEN PLOT XPOS,YPNS,@:PLOT XPOS-2, YPOS,y :GOTO 18210 
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10990 IF IHKEYC635=9 THEN PLOT XPOS+2, POS, y 

1919 IF INKEYC63)3=32 THEN PLOT XPOS+4,YPOS, y 

19119 IF INKEYC63)=128 THEN PLOT XP0S+1,YPOS, y 

19129 IF INKEYC63)=164 THEN PLOT XP0OS,YPOS,D:PLOT XPOS+2,YPOS, y :GOTO 19219 
19132 IF INKEYC222=169 THEN PLOT XPOS,YPO0S,@:PLOT XPOS, YPOS-2,y:GOTO 19219 
19149 IF INKEYC223<>-1 THEN PLOT XP0S,YPOS-2,y 

14159 IF INKEY(192=164 THEN PLOT XPOS,YPOS,@:PLOT XPOS, YP0S+2,y:GOTO 10219 
19169 IF INKEYC193<>-1 THEN PLOT XP0S, YPOS+2,y 

id THEN PLOT XPOS,YPOS,@itz=t-1:PLOT PCt,8,P3,PCt;,1,P3,;9:G 
18189 IF INKEYC382<>-1 AND t=A THEN PLOT XP0S,YPOS,2:t=1:PCP,0,8)=xP0S: 
PCP,9,13=YPOS:PRINT CHR$(7):GOTO 19210 

19194 IF INKEYCS583<>-1 THEN xP=XPOS :yP=YPOS:PCP,t,B)=XP:PCP,t,122=YP: 

PLOT PCP,t-1,@),PCP;t-1,13,2:DRAW xP,9P:tzt+1:PRINT CHR$#C(7):GOTO 19219 
19204 IF t>29 THEN PRINT"StoP":RETURN 

19214 LOCATE 1,1:PRINT USING "##";t:LOCATE 1,23:PRINT XPOS; :PRINT"/"YPOS; 
19229 GOTO 1943@ 

14234 RETURN 

12004 ’===m222222222222R22ESSESSEESSSSSSESESREESESSSSSENRESESESE Restitution 
12419 MOVE @,9 

12829 PLOT PCP,@,@3),PCP,@,13),y 

1293 FOR t=1 TO acPp) 

12849 DRAW PCP,t,@2,PCP,t,12 

12954 NEXT 

12968 PRINT CHR$< 7) 

12978 RETURN 





Il est temps à présent de passer à l'explication détaillée du 
Programme VI.4. Ce programme, comme les deux précédents, est destiné 
à être rajouté au Programme VI.1 (et à ceux qui précèdent le VI.1 dans 
son explication). 

Ce programme se décompose en trois parties principales. La première 
(lignes inférieures à 1000) est composée de lignes qui s’insèrent dans le 
Programme VI.1 pour assurer sa bonne exécution avec des polyèdres 
étagés. Nous y reviendrons lorsque nous aurons mieux compris la manière 
dont ils sont engendrés, celle-ci conditionnant évidemment leur utilisation. 

La deuxième partie, nommée plans étagés, est destinée à engendrer les 
n + l'intersections avec les plans T;. Ces intersections sont données à l’aide 
du plot baladeur, qui a été quelque peu modifié pour ne donner que des 
polygones ; le premier point est toujours enregistré séparé, les autres joints 
au précédent. Les pressions successives de la touche “e”, après 
déplacement de plot, engendreront donc une ligne brisée. D'autre part, le 
sous-programme restitution redessine, avant d’enregistrer une intersection, 
toutes les intersections précédentes; j'aurai l’occasion de dire, au 
paragraphe suivant, l’utilité de ce système. 

Précisons un peu les notations. P,, , est le v“"® point de la 4°" intersec- 
tion (avec v ou u nul éventuellement, comme toujours), et p (u, v,w) est sa 
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wisme coordonnée. La matrice p étant dimensionnée à (n,20,1), on ne 
peut mettre que 21 points par intersection, pour cause de place mémoire. 
D'autre part, la troisième coordonnée du point n’est pas p(u,v,2), mais 
z(u), puisque T, a pour équation z = z(u). 

Sur les intersections elles-mêmes, le programme se charge de les fermer, 
c’est-à-dire qu’il rejoint le dernier point avec le premier. Il est précisé 
qu’elles doivent être convexes, sinon le PCX ne saurait admettre un 
polygone concave pour face, et le programme aboutirait à une erreur. En 
outre, pour des raisons techniques, le polygone doit tourner dans le sens 
trigonométrique, et l’angle polaire du point P, + :0 doit être inférieur à 
celui de P, 4; nous allons voir pourquoi. 

Passons à la partie principale du programme, la génération du polyèdre. 

Ce programme, comme le VI.3, a un gros avantage en tout cas : c’est que 
la génération du polyèdre exige de calculer le vecteur normal de chaque 
face. Comme nous le verrons au paragraphe suivant, ces vecteurs sont 
extrêmement utiles, et même nécessaires à la gestion des parties cachées. 
Or, ils seront ici déjà tout calculés. C’est pourquoi on conserve leurs trois 
coordonnées dans la matrice n. 

Passons à la partie liens entre deux plans. Il s’agit d’engendrer le PCX,, 
c’est-à-dire ce polyèdre convexe imaginaire qui joint les deux plans T, et 
T, +1. Cette opération sera répétée pour tous les interplans, d’où la partie 
changement de plans (lignes 7500 et suivantes). 

Nous avons ici deux polygones, et nous cherchons les faces qui les 
joignent (voir Figure VI.E,c). Pour cela, nous utilisons un algorithme, 
précédé d’une amorce. 

L’algorithme consistant à trouver une face à partir de la précédente, 
l'initialisation doit nécessairement trouver une première face. Pour cela, 
on cherche l’une des faces contenant le point P,,9. Dans la suite, nous 
supposerons que tous les polygones sont de vrais polygones, c’est-à-dire 
ont au minimum trois points (1. Dès lors, il existe au moins un nombre b 
tel que P, 0P, + 1,5 Ph + 1,9 + 1 SOit une face. II ne reste plus qu’à le trouver, 
en essayant tous les b possibles (sauf b = q(p + 1) et b + 1“=”0 pour des 
raisons techniques ; à votre avis, lesquelles et comment les résoudre ?) 
(Question VI.d.) La face est bonne, en principe, si tous les autres sommets 
sont du même côté. En réalité, il suffit de s’assurer que tous les points de 


(1) A votre avis pourquoi ? Comment faire autrement ? (Question VI.c). 


SAt:E 


T, sont du même côté que ceux de T, ; ;, car le polygone Pg, ; ;, étant 
convexe et ayant une arête commune avec la face à tester, est forcément 
tout entier du même côté. C’est ici que la convexité des polygones devient 
essentielle ; sans elle, il risque de ne pas y avoir de b, donc pas d’amorce, 
donc... rien. 

Ce b étant trouvé, nous avons enfin notre première face. Il faut alors se 
préparer à l’algorithme. 

Celui-ci fonctionne à partir d’une face ABC organisée comme suit. Les 
trois points ABC joignant les deux polygones Pg, et Pg,,1, il est 
obligatoire que l’un des points soit d’un côté, et les deux autres de l’autre. 
Ces derniers, de plus, formant une arête, sont forcément successifs. 
L’algorithme appelle A le point isolé, p, le numéro de son polygone 
(P1 = p où pi = p + 1), et fg, (flag a) son numéro d'ordre en son sein. Donc 
A=P,,,f, Quant aux points B et C, ils se suivent sur le polygone p;, de 
sorte que fg, = fg. + 1. On voit la nécessité que les polygones soient 
orientés dans le même sens, car l’algorithme progresse justement dans ce 
sens-là, quelle que soit la valeur de p,. Dès lors, AC est nécessairement 
l’arête extrême de la face enregistrée juste avant ABC. 

Il en résulte (et c’est encore plus clair sur la Figure VI.E,c) que la face 
suivante, à rechercher, admet AB pour arête. On voit que, contrairement 
au PCM, le choix de l’arête de recherche n’est pas ici arbitraire, au 
contraire. 


Mais il y a mieux : le point manquant D, tel que ABD soit une face, n’est 
pas du tout arbitraire non plus. Alors que, pour le PCM, ce pouvait être 
pratiquement n'importe quel point, ici on n’a le choix qu'entre deux. 

Il s’agit en effet, obligatoirement, soit du “suivant de A”, Q, soit du 
“suivant de B”, P. Il n’y a pas d’autre possibilité, ainsi que vous vous en 
rendrez compte en méditant sur la figure. 


Dès lors, le reste est assez clair. On exécute le test des produits scalaires 
qui a été décrit pour le PCM. On sait ensuite par comparaison quel point 
est le bon, il ne reste qu’à enregistrer la face et à se préparer à engendrer la 
suivante. Pour cela, il faut redéfinir A, B, C. Ainsi, si Q est le bon point, 
alors c’est B qui est isolé dans la nouvelle face BOA. Donc B devient A, A 
devient C, car il précède Q qui devient B. Si c’est P le bon point, alors A 
reste isolé, B devient C et P devient B. Notez que, dans les deux cas, C 
passe aux oubliettes… 


L’algorithme s’arrête lorsque la face obtenue est égale à la face de 
départ. Pour en être sûr, on conserve en mémoire la valeur de fg, de 
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l'amorce (fg,,). Sur l’amorce, en outre, fg, = 0 et p = p. Quand ces trois 
valeurs se retrouvent identiquement répétées, on est revenu au point de 
départ, il n’y a donc plus qu’à changer d’interplan. 

Enfin, lorsque p + 1 dépasse n, on ne peut continuer ; la génération du 
polyèdre est terminée. 

Toutefois, dans le polyèdre final, le premier et le dernier polygones sont 
aussi des faces, que nous appellerons faces extrêmes. Ces faces, très 
simples à engendrer puisqu'il n’y a aucune opération à exécuter, posent 
toutefois un léger problème. Comme ïil faudra bien qu’elles soient 
conservées, il faut soit garder la matrice p (mais cela prend inutilement de 
la place car elle ne sert plus à rien), soit les insérer dans la matrice a, qui 
est prévue pour des faces triangulaires ; une élongation de cette matrice à q 
points (définition de g aux lignes 8020-8040) utiliserait aussi beaucoup de 
place en mémoire. Ces deux solutions étant mauvaises, j’en ai choisi une 
troisième, consistant à créer une matrice spéciale fe pour contenir ces deux 
faces abandonnées. Évidemment, cela exige de modifier un peu les 
programmes de dessin du polyèdre, etc., car il ne faut pas laisser ces 
orphelines à la traîne, d’où la première partie du programme (lignes 
inférieures à 1000), causée par la matrice fe. Mais la présence de cette 
matrice permet d’éliminer p et qg, devenues inutiles (ligne 8140). Une 
économie de mémoire est toujours bonne à prendre. 

En tout cas, ça marche. Essayez donc! 


8. SUPPRESSION DES PARTIES CACHEES DES POLYEDRES 
CONVEXES 


—————"————" ————  ——______—_—_——______———…”…”…”…”…"…”…"…"…"…"…"…"…"…"…"…"…"."…"—…".…"—…"—."—…"_—"—"— —— 


A force de m’entendre parler de la gestion des parties cachées, le lecteur 
doit être bien impatient de voir de quoi il retourne ! 


Tout d’abord, pour être convaincu de son utilité, il suffit, je pense, de 
regarder les Figures VIF et VI.F bis. Sur la première, vous voyez 
essentiellement ce que l’on peut appeler un beau fouillis. Ce n’est pourtant 
rien d’autre que le gros polyèdre de l’autre figure, qui est représenté 
d’abord toutes faces visibles, ensuite “avec parties cachées”, c’est-à-dire en 
fait au naturel. Il va sans dire que la seconde est plus agréable à l’œil, et 
plus réaliste que l’autre. 
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Figure VL.F bis 
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En effet, lorsque vous regardez un polyèdre, par exemple un dé, ou plus 
généralement n'importe quel objet, vous ne pouvez, sans miroir, le voir 
intégralement. Ainsi, pour un dé, autrement dit un cube, vous ne pouvez 
voir plus de trois faces à la fois, sauf s’il est en verre (et encore). Cela, c’est 
la réalité. Mais ce n’est pas ce que vous avez vu jusqu’à présent sur votre 
Amstrad, qui vous a bêtement et indistinctement tracé toutes les faces. de 
chacun des polyèdres que vous avez définis (ce qui, en fait, n’est déjà pas 
mal). 

Nous allons tenter à présent de remédier à ce manque, afin d'obtenir des 
polyèdres, et plus tard des objets plus complexes, qui soient quelque peu 
réalistes. 

J'ai déjà eu l’occasion d’expliquer à quel point cela pouvait être 
complexe pour les polyèdres concaves, et pour quelles raisons. 

Pour le moment, c’est donc simplement des polyèdres convexes que 
nous allons nous occuper. Cela ne sera d’ailleurs pas très long car la 
méthode est extrêmement simple. Observez la Figure VI.E, schéma d. On 
y voit un polyèdre convexe, l’écran E sur lequel on le projette, avec votre 
œil derrière. Cet écran a un vecteur normal que l’on oriente sortant, 
c’est-à-dire la pointe vers l’œil, que nous appellerons V. Je précise tout de 
suite que la norme V est indifférente. Seuls comptent sa direction et son 
sens. 


D'autre part, chaque face a un vecteur normal (double flèche). A côté 
de chacun de ses vecteurs normaux (dont la norme est également 
indifférente), nous voyons un représentant du vecteur V, ce qui permet de 
mettre en valeur l’angle qui sépare ces deux vecteurs. Or, constatant que, 
pour l’œil, seules les deux faces de droite sont visibles, nous pouvons faire 
l’observation suivante sur ces angles. 

Soit l’angle est obtus (face marquée d’un 1), et la face est invisible. Soit 
l’angle est aigu (face 2), et la face est visible. Soit (cas limite de la face 3) 
l'angle est droit, et la face est les deux à la fois : elle est vue par la tranche. 
Comme cela ne rajoute rien au dessin à faire sur l’écran, nous pouvons la 
considérer comme invisible. 

Nous savons à présent sur quoi baser notre appréciation. Mais plutôt que 
de calculer cet angle, ce qui serait pénible, nous pouvons ajouter cette 
remarque : si l’on appelle prod le produit scalaire de V et du vecteur 
normal de la face considérée, ce prod est du même signe que le cosinus de 
l'angle séparant les deux vecteurs (voir Chapitre II). Il est donc positif si 
l’angle est aigu (face visible), négatif sinon. Il suffit donc de calculer prod 
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et de voir son signe. Or, quoi de plus facile à calculer qu’un produit 
scalaire ? 

Le seul problème qui subsiste, si l’on peut dire, c’est la présence des 
vecteurs normaux, qu’il faut calculer. C’est pourquoi j’ai tenu à conserver 
ceux qui sont automatiquement créés par le Programme VI.4. C’est là la 
supériorité de ce programme sur le Programme VI.2, où les vecteurs 
normaux ne sont pas calculés. 


FROGRAMME TS 





+AQ ’==szss=ssasszzs-zs-2sses=szses-s--ss-ssazs Calcul des vecteurs normaux 
314 DIM ncf-1,2) 

324 FOR t=9 TO f-1 

239 afzact,9,4):al=att, 4,1 ):af=act,M,2) 

344 b=act,1,@):bh1=act,1.12:b2=act,1.2) 

459 cGsact,2,43:rizatt,2,1):r?2act,2,2) 

364 x=(b1-a12#4Cc2-22)-Ch2-a73#(c1-a1 

404 y=(b2-a? 34 cD-a99-Ch4-a4 34 c?-3279 

389 7z=(b-añ)%Cc1-a1-Ch1l-a1)#CcH-3H) 

399 IF t=f-1 THEN te=@ FLSE tezt+1 

49 xte=acte,G,H):ytezaite 4,1):7tezacte, 4,21 
414 Testeur=(xte-an)k>x+(ute-al%y+(zte-a22*z 
429 IF Testeur 29 THEN “=-x:y=-y:2=-7 

439 nét,4)=x 

+44 not,1)=y 

459 n°t,29=z 

464 NEXT 

623 Prod=clks2%nct,@+s1%s?%kntt, 1)+r2%nct.2) 
639 IF Prod<=@ GOTO 724 








=== Tous Polsedres 
PQ ’=s=se=s22= SRS2ESR2SZz2S2S= SES S2S=SSuES Entree des donnees 


34 MODE 1:PRINT"'Le Poluedre #st-il à <umetrie""de revolution?" 
DEG 


19 ’sasnasazzesssussansz=zezaz-ssssszaz=2sz-==22s 





49 WHILE INKEY$="":MEND 

SQ IF INKEYC343<>-1 GOTO 3848 

64 CLS:PRINT"Voulez-vous definir le Polyedre Par" 
74 PRINT'"'des Plans eta3e57" 

84 WHILE INKEY$="":WEND 

94 IF INKEYC343<>-1 GOTO 5488 

194 CLS:PRINT'"'Le Polyedre est donc Quelconque." 
119 FOR t=9 TO 3OAA:NEXT 

129 CLS 

495 IF f139=1 THEN umax=2 ELSF umax=AACt)-1 

499 FOR u=A TO umax 

521 IF fla2=9 GOTO 534 

632 IF fla9=1 THEN umax=? ELSE umax=AACt )-1 

635 FOR u=@ TO umax 

725 IF fla9=9 GOTO 7084 

3665 fla9=9 











> 


N'importe, le Programme VI.S suppléera à ces insuffisances. Les 
lignes 300 à 460 permettent de calculer les vecteurs normaux quand ce 
n’est déjà fait (d’où la ligne 305 du Programme VI.4). Peu de commen- 
taires sur ce point, car nous l’avons déjà vu en Figure VI.E,b. Notez 
seulement que le Programme VI.2 est conçu de telle sorte que le premier 
point d’une face n’appartient pas à la précédente, et peut donc servir de 
point D de test. 

Quant aux lignes 625 et 630, ce sont elles qui assurent la gestion des 
parties cachées, en calculant prod et en déterminant son signe. Si celui-ci 
est négatif, alors la face ne doit pas être tracée, on passe à la suivante. 

A présent, il ne vous reste plus qu’à amalgamer le Programme VI.1, 
précédé comme il convient, avec les Programmes VI.2, VI.4, VIS et VI.6 
(dans cet ordre) pour obtenir un très gros programme : tous polyèdres, qui 
cumulera à peu près tout ce que nous avons vu jusqu’à présent. Il sera 
parfaitement complet si vous souhaitez, après la ligne 120, rajouter les 
INPUT permettant de rentrer un polyèdre quelconque ne pouvant l’être 
avec les deux méthodes jusqu'ici exposées. Si vous avez eu le courage de 
réaliser le Programme VI.3, rien ne vous empêche de l’insérer en 
supplément ! 

Avant de vous laisser à de polyédriques chimères, je dois encore penser 
au lecteur qui se demande avec angoisse comment il pourra savoir si son 
polyèdre est convexe ou non, à partir des systèmes “Polyèdres à répétition 
cylindrique” et “Polyèdres étagés”. 

Nous avons vu que, pour ces derniers, il était nécessaire que les 
polygones soient convexes. Un polygone convexe n’est pas difficile à 
reconnaître, avec un peu d’habitude. Au début, dessinez votre polygone en 
couleur (en rouge, par exemple). Puis, en noir, joignez chaque sommet à 
tous les autres, sans repasser les traits rouges. Si tous les traits noirs sont à 
l’intérieur de la ligne rouge, votre polygone est convexe, c’est tout simple. 

Mais, pour les polyèdres étagés, ce n’est pas suffisant. Le polyèdre 
obtenu ne sera convexe qu’à d’autres conditions. En particulier, deux 
polygones successifs doivent être contenus l’un dans l’autre (c’est pour cela 
que le Programme VI.4 redessine les polygones précédents). De plus, cela 
doit croître, puis décroître, c’est-à-dire que le deuxième doit contenir le 
premier, le troisième le deuxième, etc., puis le sens s’inverser (mais une 
seule fois) de telle sorte qu’à la fin c’est le dernier qui est inclus dans 
l’avant-dernier. Ensuite votre polyèdre sera peut-être convexe, surtout si 
vous avez pris la précaution d’espacer beaucoup (grosse différence 
d’ordonnées) deux polygones successifs dont l’un est nettement plus gros 
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que l’autre. Je sortirais de mon sujet en en disant davantage, mais je pense 
que cela devrait suffire. 

Pour les polyèdres à répétition cylindrique, c’est plus simple : il faut et il 
suffit, pour assurer leur convexité, que la baleine soit convexe par rapport à 
l’axe Oz, ce qui se vérifie ainsi : considérez l’extrémité supérieure A de la 
baleine, et a sa projection orthogonale sur Oz puis de même B l’extrémité 
inférieure et b. Dès lors, l’ensemble (segment ab (sur Oz) + segment bB 
+ baleine + segment Aa) forme une ligne brisée fermée. 

On dit que la baleine est convexe par rapport à Oz, si cette ligne brisée 
fermée est un polygone convexe. Notez que cela pourrait même ne pas être 
un polygone, si la baleine traverse l’axe Oz. 

Vous voilà à présent paré pour tout ce qui touche les polyèdres, ou 
presque. Mais c’est seulement plus tard que nous aurons l’occasion de 
parler des parties cachées des polyèdres concaves, qui sont assez difficiles. 
Pour le moment, nous allons étudier un sujet complémentaire des 
polyèdres, les surfaces bombées. 
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REPONSES AUX QUESTIONS POSEES DANS CE CHAPITRE 


Question VI.a 


Tout simplement en modifiant le programme de tracé, pour qu’il ne 
trace que les deux premières arêtes de chacune des faces tétragonales, et 
même seulement la première pour les faces tétragonales du bas. En effet, 
sur les faces tétragonales, la deuxième arête est commune à la face située 
en dessous, la troisième à celle qui suit, et la dernière à celle du dessus. 


Question VI.b 


Il suffit, chaque fois que l’on trouve une nouvelle face ABC, de calculer 
les produits scalaires de AB avec tous les vecteurs normaux des faces 
précédentes. Lorsqu'un tel produit se trouve nul, la face dont on a pris le 
vecteur normal est parallèle à ABC. Reste à vérifier qu’elles sont bien sur 
le même plan (car elles peuvent être seulement parallèles), puis à les 
amalgamer. 


Question VI.c 


Pour tester la validité d’une face, le programme a besoin d’un point sur 
l’un des polygones qui n’appartienne pas à la face à tester. C’est obligatoire 
si les polygones ont au moins trois sommets, mais si l’un d’entre eux n’en a 
que deux, ou un seul, cela risque de poser de graves problèmes. Deux 
solutions sont possibles : 


e Changer le programme avec des routines spéciales, mais c’est un peu 
lourd. 


e Considérer un troisième point, très proche du premier (différence de 
0,01), donc invisible, mais qui aidera le programme (c’est le même 


s 


principe que pour les faces triangulaires des polyèdres à répétition 
cylindrique). 


Question VI.d 


Le point suivant de b est b +1, sauf si b = q(p). Dans ce cas, il faudrait 
remplacer dans tout le programme les b + 1 par des b;, et taper: 


IFb = q(p) THEN bi = 0ELSE b1 = b+1 


en ligne 6140. 
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VII 
TOUJOURS PLUS LOIN, 
TOUJOURS MIEUX 





Après avoir vu des méthodes très rigoureuses et superbes, et obtenu finalement 
un échec partiel puisque nous ne savons pas encore tracer des polyèdres concaves 
sans parties cachées, nous allons faire ici l'éloge de trucs simplificateurs dus à 
certaines particularités des objets à tracer. Cet éloge sera soutenu par deux 
exemples un peu difficiles, mais très intéressants. 

Le premier permet de tracer en trois dimensions un appartement, un labyrinthe, 
ou d’une façon générale toute pièce ou ensemble de pièces aux murs verticaux. Au 
passage, nous expliquerons comment, par extension, il est possible de gérer les 
parties cachées des polyèdres concaves, mais il n’y aura pas de programme (il 
risquerait de prendre des dimensions astronomiques!). Le programme pour 
l’“appartement” est déjà bien assez long, mais vous verrez qu’il est assez puissant ; 
or ce genre de chose peut toujours servir. 

Le second exemple traite des surfaces “bombées”, c’est-à-dire non planes. 
L'usage de ces surfaces apporte un complément indispensable aux polyèdres. Leur 
combinaison, comme il sera expliqué, est le fondement de la fameuse “C.A.0” 
(Conception Assistée par Ordinateur), qui permet de tracer ainsi à peu près 
n'importe quoi, sans parties cachées. C’est pourquoi j'ai jugé utile de traiter de 
cette question, quoique le sujet soit plutôt aride. Aussi ne vous inquiétez pas si tout 
n’est pas très clair, et n’hésitez pas à relire plusieurs fois, voire à lire les chapitres 
suivants (moins difficiles) avant de revenir à celui-ci. Je crois néanmoins que le jeu 
en vaut la chandelle, et qu’il eût été dommage de ne pas parler de ces surfaces. 


1. _S’ADAPTER AUX PARTICULARITES DES OBJETS TRACES 





Il est rare qu’il existe une méthode générale absolue pour toute une 
catégorie d'objets. Même lorsqu'elle existe, elle est souvent si longue qu'il 
vaut mieux, effectivement, s’adapter aux particularités des objets tracés. 
Nous avons déjà vu cela avec les polyèdres à répétition cylindrique et les 
polyèdres étagés. Plus l’objet à tracer est susceptible d’être complexe, et 
plus cette règle s'impose. 

Nous allons en voir deux exemples, mais souvenez-vous que l’on peut 
presque toujours trouver une simplification. C’est encore plus le cas, 
naturellement, dans un jeu où il se trouve quelques décors seulement, ou 
quelques “vaisseaux spatiaux”, etc. 

Prenons un exemple concret. Imaginons un jeu avec des chars de 
combat, tous les mêmes. Un char peut, en gros, être considéré comme un 
polyèdre, convexe de surcroît, et même étagé à la rigueur, à condition 
qu'on en omette un détail : le canon. Ce canon, d’autre part, est un petit 
cylindre (par le rayon), assez long, et mobile. Pourquoi dès lors ne pas 
tracer le corps de la machine, d’une part, comme un polyèdre étagé, puis le 
canon, d’autre part, comme un cylindre (voir Paragraphe 3 pour le tracé) ? 
Pour parachever le travail, il suffit d’effacer les traits du polyèdre situés 
derrière le canon, et voilà un char très convenable, en utilisant deux des 
tracés rendus possibles dans ce livre. 

Pour vous convaincre totalement, nous allons appliquer tout cela à des 
exemples précis dont j’ai parlé en introduction. 


2._LE LABYRINTHE OU L’APPARTEMENT DE REVE 





Le long Programme VII.1 va permettre de créer en trois dimensions des 
objets particuliers. Lesquels ? Ce sont des objets obtenus par élévation. 
Cela signifie que, à partir d’un plan au sol constitué de segments, le 
programme va engendrer un objet en trois dimensions, chaque segment 
devenant un mur dont la base est la même que le segment, et dont les côtés 
sont verticaux et de longueur donnée au préalable. L’objet ainsi obtenu 
pourra ensuite être déplacé comme pour les polyèdres. Cela pourra être un 
appartement, par exemple, si vous en entrez le plan, un labyrinthe, ou tout 
autre ensemble de murs ; on en comprend dès lors l’usage, forcément assez 
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répandu dans les jeux (en outre, l'appartement sera plus mobile que ceux, 
visibles dans certains jeux, où les murs sont résolument fixes et vus 
toujours selon le même angle), et de surcroît, cela peut même servir 
professionnellement. Voyez ainsi la Figure VILA. 





Figure VILA 


Cet objet, nous l’appellerons à présent l’appartement, sans nous soucier 
de son usage réel, puisque ce n’est pas le but que nous poursuivons. Vous 
voyez que je tiens tout de même à rester assez général. 

Mais pas trop tout de même. Les particularités essentielles de ce type 
d'objets sont d'intérêt pratique et de commodité informatique. L'intérêt 
pratique réside dans leur conception : un plan au sol suffit. Nous savons 
comment le faire facilement, grâce au plot baladeur. Ainsi les premières 
lignes du Programme VII,1 sont-elles très largement inspirées, voire 
recopiées, du Programme IV.1. 

Pour expliquer la commodité informatique, il faut pouvoir se repérer. 
Comparons donc avec les polyèdres concaves généraux. Par rapport à 
ceux-ci, nous semblons y perdre. Car, non seulement notre appartement 
hérite de leurs tares (car les murs peuvent également être partiellement 
cachés, et donc être tracés en mille morceaux), mais, en outre, il n’a même 
pas l’avantage d’être un polyèdre car il n’a ni plancher ni plafond, donc pas 
d'intérieur et d’extérieur, et certaines faces (murs en fait) sont au centre de 
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plusieurs autres. En réalité, quoique le principe soit globalement le même, 
l’appartement est nettement plus facile à tracer en trois dimensions. En 
voici les raisons : 


1. Alors que les faces d’un polyèdre peuvent avoir quarante côtés, un mur 
n’en a que quatre, de toute façon. 

2. De ces quatre côtés, deux sont verticaux, ce qui est infiniment précieux, 
comme nous le verrons dans un instant. 


3. Les murs sont toujours des rectangles; leur projection sera donc 
toujours un parallélogramme, ce qui est aussi précieux. 


Pour mieux nous expliquer, nous allons distinguer trois parties dans le 
tracé de l’appartement. La première est constituée de toutes les arêtes qui 
feraient partie du plafond, s’il y en avait un: c’est la partie haute. La 
deuxième est formée de toutes les arêtes qui feraient partie du plancher, 
s’il y en avait un: c’est la partie basse. La partie intermédiaire est formée 
par toutes les arêtes verticales des murs. 

Nous admettrons les propriétés suivantes : 


e Toutes les arêtes de la partie haute sont entièrement visibles lorsque 
l'appartement est vu par en haut (ce que nous supposerons). 


e Toutes les arêtes verticales sont en un seul morceau ; elles ne sont pas 
forcément entièrement visibles mais, de toute façon, si elles sont 
coupées, c’est forcément par une arête de la partie haute, et dès lors leur 
partie supérieure est visible, le reste ne l’est plus. 

e Seules les arêtes de la partie inférieure posent un problème: elles 
peuvent être visibles en de nombreux morceaux, il n’y a pas de cas 
vraiment général. Mais cela ne fait qu’une arête sur quatre, alors que 
dans les polyèdres concaves toutes les arêtes étaient susceptibles d’être 
coupées en morceaux. 


e Dernier avantage enfin: sauf lorsque l’appartement est vu par la 
tranche, aucun mur ne peut en dissimuler complètement un autre, alors 
que cela arrive sur les polyèdres, et c’est extrêmement ennuyeux car 
difficile à repérer. 


Malgré tous ces avantages, le tracé de l’appartement est encore assez 
long (et évidemment d’autant plus qu’il y a plus de murs). C’est pourquoi, 
afin de maintenir malgré tout l’animation, j'ai pris le parti d'exécuter 
d’abord tous les calculs (en les stockant ensuite), puis seulement d’effacer 
l'écran et de tracer le résultat. Ne vous étonnez donc pas si, au cours de 


— 128 - 


l'exécution du programme, les touches semblent sans effet; en fait, le 
calcul est en cours. 

Mais de quel calcul s’agit-il? Pour mieux me faire comprendre, je 
m'appuierai sur la Figure VII.B. 





Figure VII.B 
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plan au sol 
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INTERSECTIONS D'UN MUR 


Mur t:P,Q,R,S,; 


V:=RS:=P,Q 


Initialiser q :uZ 





Partie basse 





— 131 - 


APPARTEMENT (suite) 


Ÿ 


1" 


Verticale 









P,R: coupe 
R, Su (le + haut) 










inters; 
dans p 






b(t,4) +10 





2° 
Verticale 








Q; S: coupe 
RS, (le + haut) 






si SO, alors 
b (t,4) csg 







inters. 
dans p 
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FROGRAMME WII. 1 












ZSZ2222222z ssss=sz==ssez===z= Plot baladeur 
MODE 1:IHK @,1: BORDER 1:INK 1,24:PEN 1:IHK 2,6 

34 DIM 3(29&,1) 

48 DEFINT h,isuwt 

54 ORIGIN 329,268 

74 PLOT @,4,1:t=4 

39 UHILE INKEYC793=-1 AND INKEYC582=-1 AND INKEYC74)=-1 AND INKEYC752=-1 
AND INKEYC723=-1 AND INKEYC733=-1 AND INKEYC682=-1 AND INKEYC77)=-1 : WEND 

98 IF INKEY(683<>-1 THEN n=t:GOTO 594 

194 i=INKEYC740):IF i<>-1 THEN v=g:ius-2-i/16:GOSUP 399 

119 1=INKEYC7S2):IF i<2-1 THEN v=H:us 2+i/16:GO0SUB 399 

129 1=INKEYCF735:IF i<>-1 THEN u=ÿ:v=-2-i/16:GOSUB 368 

134 i=INKEYC72):IF i<>-1 THEN u=ñivs 2+1/16:G0SUB 39Q 

149 IF INKEYC733<2>-1 THEN PLOT XPOS,YPOS,G:tat-1:DRAW act,92),act, 1): 

PLOT aût,@3,act,13,1:GO0T0 189 

169 IF INKEYCS83<>-1 GOTO 496 

178 IF t>193 THEN FRINT'StoP":n=249:G0T0 548 

184 LOCATE 1,1:PRINT USING "###"ot 

134 AE 1,25 :PRINT XPOS; : PRINT"-"YPOS; 

246 GOTO 8 

300 ’=ms-sss-scazs-susecseszassess=s2s2-=csascsssaussz== Placement du Point 
319 PLOT “POS, YPOS,H 

324 HSTESTÉ KPOS-+u: YPOS+v à 

339 PLOT XPOS+u, YPOS+v, 1 

348 RETURH 

AUD ’zzzsssssssnseouesssss===2ss=seasesss2=-=ss=ssssss Enregistrement du Point 
419 tt=t MODCZ 

429 IF tt=@ THEN PLOT XPOS,YPOS,2:açt,92)=XPOS: act, 1 2=YPOS :t=t+1: PRINT 
CHR$(7 >: GÜTO 189 

439 at, @2=xPOS act, 12=YPOS :PLOT a£t-1,8),açt-1,1),2:DRAW act,@),act,1): 
tat+l:PRINT CHR$&7):GOTO 184 

540 sssss=ss SSSsrsas=ssszsssssssszss2sss=zs=s=esssszasses [Jnitialisation 
PLOT @,9,1 








INPUT "Hauteur des murs ";HH 
MODE 1:IHK G,4:BORDER G:PEN 1:ORIGIN 326,296 
m=n/2-1:theta=4S:psi=4s 
G CIM bäém, 45 
DIM Pt 4Kris À 2 
HC 





PREPARATION DU DESSIN 





514 ci=COSCPsi):s1=SINCPSi) 

628 c£=C0S theta ï:s2=S INC theta à 

639 Hh=INTCHH#s:202: i=@ 

644 FOR t=9 TO m 

654 UzINT(s1#a02#t,9)-c1kacZ#t, 102 

668 v=INTÉ Sika 2#t+1,03-c1#ac 2kt+1, 101) 

678 IF uv THEN béct,@oi=v:bxct,1)=u ELSE bXCt,@au:bXCt, 1)=v 





688 u1=INT(EZ2#HH-c2#4Cc1#ac2#t, 9)+s1#ac2#t, 1230 
694 Vl=INT(SZ#HH-c2#é cl#ac Z#t+1,00+s51#aC2#t+1,1222 
78 IF uv THEN bxct,Zi=vl:bACt,3)=u1 ELSE bXCt,7)=ul:bxct,33)=vi 
"14 HEXT 
24 FÜR t=@ TO m 
GOTO 394 






====2222= [ntersections d’un mur 
=bxCt,3)-h:V@=c-a:Vi=d-b 


2E*= Hate (ons partie basse 


FOR u=g TO m 
quat=VkC DAC 0, 32-b%Cu 222-VLKCACU, 1 )-bHCU, 22) 

IF quot=9 GOTO 960 

lambda = CCa-bAC us DE bXCU, 3-40, 222 b-bCu, 2 DKCBXCU, 1 2-b4CU 92227 





quot 

356 IF lambda<G AND lambda>-1 THEN GOSUB 1489 
964 1F Vä=9 GOTO 9399 

979 x=bx(u,6):uñsba(u,Z):f9=-1:GOSUB 1308 

989 x=bu, 1:4@=bxCu,33:f921:GOSUB 1399 

394 HEXT u. 
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1484 bACt,4)=k:IF k=Q THEN bxct,43=169:GOTO 1149 

1914 fa=g:fas=4 

1628 FÜR v=à TO k-1 

1939 IF fakq%(v,22>4 THEN bXxct,4)=b%Ct,42-1:1IF fa=-1 GOTO 1984 ELSE izi-1: 
GOTO 1954 

1944 IF v>9 THEN IF 4%Cv,9)=q%(v-1,@) THEN j=ji-2+fg9s:bxCt, 4)=bXact, 43-2+f9s: 


1958 PAC i,9)=9%Cv,D):pXxl ji, 13=9%Cv, 10 
1968 fa=9%iv,2) 
1979 j=j+1 






t:4)=9 THEN bXCt,42=199 
=SS=E== inters. ere verticale 





XS3:9 

1129 FÜR u=9 TO m 

1134 IF x<=b%Cu,8) OR x>=b%@u,12 GOTO 1164 

1149 yG=y:u=brou, 234€ a-bAçu, 824 b4CU, 3)-bACu,232/Cb4CU, 12-bXCU, 93 
1159 IF s>=b+h OR y<=yG THEN y=99 

1169 HEXT:IF s>b GOTO 145@ 

1174 FOR u=6 TO m 

1189 IF b+h=bziu,2) AND azb%(u,@) AND u<>t GOTO 1219 

1196 NEXT 

1264 GOTO 1699 

1214 IF Y1>(bX(u,32-bxiu,2)3 THEN bXct, 42=bXCt, 43)+18 

1228 GOTO 1668 

1299 ’=====22222= ====2== jnters. avec verticale 

1319 IF x<=a OR x>=c THEN RETURN 

1329 y=INTCb+Cx-a 2#V1/V@ 0 

1330 IF y>=s9 OR y<=49-h THEN RETURH 

134 GOTO 1568 

1499 ’===s====essssseszezzzszz= jnters., avec oblique 

1419 Xx=INT(a-lambda#V@):IF x<=b4(u,9) OR x>=bXCu, 12 THEN RETURN 
1424 y=INT(b-lambda* 1 

1439 IF Vi<(b%xCu,3)-bx(u,23) THEN f9=-1 ELSE f9=1 

1448 GOTO 1594 

1459 ’===z==sz=e==s==szz jnters, avec Partie haute 

1469 bACt,42=-bACt, 4) 

147G PAC j,D2=x: PAC), 12=y: j=i+1 

1489 PAC ji, D)=c:PpXC ji, 12=d: j=j+1 

1496 GOTO 1698 

1599 ’==sssseseseesses-sse==sesesssssz= Enregistrement dans Pile secondaire 
1516 IF x<9%(0,6) OR k=Q THEN vv=@:GOTO 1558 

1529 vv=k FOR v=D TO k-1 

1530 IF x<4%Cv+1,8) AND x2=9%Cv,9) THEN vvzv+1:COTO 1559 
1548 NEXT 

1359 FOR v=k TO vyu+l STEP -1 

1369 4%(V,D)=9%Cv-1,9):q%4Cv, 1)=q%Cv-1,13):9%Cv,23=q%Cv-1,2) 









Au, Lzu qu, Z=fa 
inters. Zeme verticale 


x=c:y=d 
1629 FOR u=@ TO m 
1638 IF x<=b4Cu,9) OR x>=bXCu,12 GOTO 1664 
1649 yGzy :y=hXCU, 234 c-bACu, 8) KChACu, 3)-biCu, 233/CbACu, 13-bkcu, D) 
1659 IF y>=dth OR y<=39 THEN 4=yû 
166@ HEXT 
16784 IF y<=d GOTO 749 
1689 IF bxct,43<4 THEN PAC j-1,92=x:PXC j-1,10=4 :GOTO 749 
1699 bAit,4)=-bxCt,4) 
179G PAC j,@ =: 
1714 PXCi,@)=x:P 
1729 GOTO 74g 
1398 ’=== 
1916 IF a 








Qi, 19=4:. 






THEH E=li 


1929 IF a=32 THEN b=/4 
1934 IF a=128 THEN b=S 
1944 IF 2=169 THEN b=45 








2918 a$=INKEYS:IF a8="" GOTO 2919 is 
2024 3=INKEYC34):IF a<>-1 THEN GUSUE 1909-Psi=Psi-b:GOTO 696 
2430 a=INKEYC27):1F a€>-1 THEN GOSUB 1989:Psi=psi+b GOTO 69% 
2949 a3=INKEYCE7):IF 2€0-1 THEN GOSUB 1989:thetastheta-b:GÜTO 698 
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a=INKEYCS95:IF a<>-1 THEN GOSUB 1964:theta=theta+b:GOTO 69@ 
IF_INKEY(792<3>-1 THEN CLS :END 

GOTO 2414 
massas=szszszsszz2-=22z2s 
CLS: j=9 

FOR t=@ TO m 
KG=ABSC LAC t, 433:k=K@ MODC 195 





IF K@=108 THEH Ka=@ 
PLOT bit, 12,bxit,33:DRAU bxct.@5,b4ct,22 
IF bxct,43=-164 THEN DRAW PXCi,@2,PXC j, 13: MOVE PXCi+1,9),P%C j+1,102: 
bACt,1),bXCt,33:j=j+2:GOTO 314% 
IF bXxCt,43=-11@ THEN ji=i+2:PLOT PX<i-1,92,P%C i-1,102: 
bxct,13,b4ct,33:GOTO 314% 
IF Kä=114& GOTO 3116 
IF bxct,43<G GOTO 3169 
IF kK<>KG THEH F93=1:MOVE PXcj,63,PXC i,12:GOTO 3390 
DRAUR @,-h 
à IF k£>@G THEN fa=-j:DRAU PXc i,49,PXC i,12:GOTO 3394 


DRAM bXct,12,b%Ct,32-h:DRANR G,h 
NEXT + 
GOTO 2644 


G DRAU PC j+k,@2,PXC ji+k 1) 


IF bXét,23=P%C i+k,13+h AND K@=k THEN f9=-1:DRAW P4Cj,9),P%C j,1): 
3399 

Fasi:MÔVE PA j,9ù,pXC i,1:GOTO 3399 

r=sz==ss=-=s==sez=z= Dessin Parties basses 








fa=-fa 





Ji=i+k 

IF f9=1 THEH DRAWU bat, 15.b%Ct,32-h:DRAU bXCt,12,b%Ct,3) 

GOTO 3144 

A j=j+k+2 

IF fa=1 THEH DRAW  PXCi-1.@),P% j-1,13 ELSE PLOT PXCj-1,8),P%C i-1,1) 
DRAU bxCt,13,b%€t,33:GOTO 3144 








Tout d’abord, le programme travaille mur après mur. Rappelons que la 
matrice a contient les segments qui forment la vue en plan de l’appar- 
tement. Vous constaterez en effet que, au cours de l’utilisation du plot 
baladeur, seuls des segments sont enregistrés, en ce sens que si le nombre 
affiché en haut (#) est pair, le point enregistré (par la touche e) sera isolé, 
sinon il sera rejoint au précédent. Aussi n’oubliez pas, si vous souhaitez 
faire deux segments jointifs, d'enregistrer deux fois le point de jonction. 
J'aurai de toute façon l’occasion de donner d’autres conseils de bonne 


utilisation de cette première partie du programme. 


Une fois votre plan engrangé dans la matrice a, le programme demande 
la hauteur des murs HH. (Donnez une valeur importante, par 
exemple 60.) Cela fait, on passe à l’alternance : attente d’une touche, 


dessin, attente d’une touche, etc., comme pour les polyèdres. De même, 


les deux angles psi et thêta sont initialisés à 45 degrés. 
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Soit un segment de la matrice a. Le programme, au cours de ses calculs 
(lignes 600 à 1800), va transformer ce segment, comme les autres, en un 
mur. Soit { le numéro de ce segment. Il s’agit du segment joignant les 
points n° 2ret 21+ 1 de la matrice a. Soit R et S les points projection des 
points initiaux du segment sur l’écran, et P et Q la projection des points de 
coordonnées (a (21,0), a (21,1), HH) et idem avec 21 + 1 pour Q. L’axe Oz 
étant vertical (c’est ici essentiel), R est en dessous de P, et S en dessous de 
Q. La distance entre R et P, ou entre S et O, est h = HH : s,. Cette valeur 
h représente la hauteur de tous les murs en projection sur l’écran. C’est 
donc une constante, tant que les angles n’ont pas changé. A présent, soit 
b(t,0),b (1,2) les coordonnées projetées de P, et b(t,1), b(t,3) celles de 
Q. Les coordonnées (a,b) de R et (c,d) de S s’en déduisent aisément : 
a=b(t,0) et c=b(t,1) (points sur la même verticale), et b=b(t,2)—-h, 
d=b(t,3)-h (.. à une distance h). On a ainsi assez facilement les 
coordonnées des quatre coins du mur £. 

Je dois préciser que, pour simplifier les calculs d’une part, pour ne pas 
alourdir la mémoire d’autre part, toutes ces matrices sont à coefficients 
entiers, même est pris entier, et ainsi de tout ce qui sera calculé par la 
suite. 

En ligne 600 et suivantes, on remplit donc les quatre premières colonnes 
de la matrice b (pour la cinquième, nous y reviendrons), mais avec une 
précision importante: en mettant toujours en premier le point dont 
l’abscisse est minimale. Pour toute valeur de f, b (t,0) est inférieur à b(t,1) 
(donc a est inférieur à c). Ce, non par caprice, mais par nécessité. 

Ces calculs faits, on passe à l’étude mur après mur (lignes 800 à 1800). 
Soit un mur PORS comme celui de la Figure VII.B, schéma a. On voit que 
la partie basse de ce mur est interrompue en trois points, I, J, K, et que, 
des deux côtés, un seul est interrompu par une autre face, c’est le côté QS, 
coupé en L. Ce sont ces points I, J, K, L qu’il s’agit de trouver, puis de 
calculer et enfin de stocker afin de les restituer. Cette restitution est bien 
sûr impossible si l’ordinateur ne sait pas d’où viennent ces points ni de quel 
mur ils proviennent. D'où le rôle de l’indicateur b (t,4) qui, pour chaque 
mur, renseigne sur les points suivants : 


e Par son signe, sur l’état des verticales ; s’il est positif, les deux verticales 
sont entières, sinon l’une au moins est coupée. 

e Par sa valeur absolue, qui est un nombre entier d’au plus trois chiffres ; si 
elle est supérieure à 100, c’est que la partie basse RS n’est pas 
interrompue ; si elle est supérieure à 10 (chiffre des dizaines mis, en fait), 
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c’est que la première verticale PR est commune à un autre mur, sinon 
cette verticale est isolée. 


e Enfin, le chiffre des unités indique le nombre de points situés sur RS, et 
où il y a interruption (c’est-à-dire où l’on passe du visible à l’invisible, ou 
l'inverse). 


Dans l'exemple de la Figure VII.B.a, cet indicateur vaut — 3. En effet: 
e — signe négatif, car la seconde verticale est interrompue. 


e Valeur absolue 003 car: 
RS est interrompue (d’où le premier 0). 


La première verticale PR n'appartient pas à un autre mur (d’où le 
second 0). 


Enfin, 3 est le nombre de points d’intersection de la partie basse 
(1, J, K). 


Je reconnais que ce codage n’est pas d’une folle simplicité, mais il évite 
d'utiliser plusieurs flags ou indicateurs, ce qui rallongerait démesurément 
la matrice b et risquerait d’engendrer un overflow. Il faudrait exactement 
deux flags et un indicateur, soit deux colonnes supplémentaires. 

Cet indicateur renseigne sur l’état du mur. Quant aux coordonnées des 
points concernés, autres que P, Q, R, S, elles sont stockées dans l’ordre 
dans la matrice p (qui joue le rôle de pile). Par exemple, lors de la lecture 
de l’état du mur, le compteur j aura une certaine valeur ; chaque fois que le 
programme de traçage (lignes 3000 et suivantes) aura été chercher un point 
dans la pile, il augmentera j pour que ce compteur pointe sur le point 
suivant. 

Reste à savoir comment ces points sont trouvés, et comment l'indicateur 
sera positionné. 


Tout d’abord, de la ligne 900 à la ligne 1100, le programme cherche les 
intersections de la partie basse ; d’une part avec toutes les autres parties 
basses (lignes 920 à 950), puis avec les premières (ligne 970) et dernières 
(ligne 980) verticales. Peu importe en réalité le détail des calculs ; nous ne 
nous y attarderons pas car c’est un simple calcul d’intersection de droites, 
avec vérification (les points d’intersection doivent se trouver sur les 
segments voulus). Au fur et à mesure que ces points d’intersection sont 
calculés, ils sont stockés sur une petite matrice (pile secondaire g), mais 
classés par ordre d’abscisses croissantes. En outre, la dernière colonne de q 
contient un flag fg. Ce flag est à — 1 si le point est de type rentrant, à +1 
s’il est de type sortant. Dans le premier cas, le trait s’arrête au point et 
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rentre derrière l’autre mur, donc est caché, c’est le cas des points I et K sur 
la Figure VII.B.a. Dans le second cas, le trait semble sortir de derrière 
l’autre mur, comme pour le point J. 

Lorsque toutes les autres faces ont été examinées, on va faire le tri dans 
cette pile secondaire avant de replacer les points sur la pile principale. En 
effet, examinez par exemple sur la Figure VII.B, schéma 2 du b, la 
situation du point J. Si le plan 2 n’existait pas, J serait un sortant. Mais, à 
cause du plan 2, J devient un faux sortant ; le trait reste en pointillé après y 
être passé. Le vrai sortant est ici K. Les points étant classés par ordre 
d’abscisses croissantes dans g, J se trouve avant K ; or, ce point J n’a aucun 
intérêt, aucun trait visible n’y aboutit, il doit donc être éliminé. C’est ce qui 
se passe dans les lignes 1000 à 1080, lors du transfert d’une pile à l’autre. 
La ligne 1030 en effet exclut qu’il y ait deux points successifs ayant la 
même nature, et ce, de la façon suivante : si deux sortants se suivent, on 
garde le second ; si deux rentrants se suivent, on garde le premier. 


Dans cette partie essentielle du programme, on exclut également les 
points multiples. En effet, toujours sur ce même schéma, en b;, le point I 
est un point double ; appartenant à deux faces, il va se trouver deux fois sur 
la pile provisoire. Il n’y aura pas de problème, car il s’y trouvera deux fois 
avec le même flag (deux fois rentrant ici). L’un des deux sera donc éliminé, 
et I ne sera stocké qu’une fois sur la pile principale p. 


Mais que se passera-t-il dans un cas plus délicat, comme par exemple 
celui du schéma b;? En effet, on trouvera sur la pile secondaire les points 
suivants: I(r), J (s), J(r), J(r), K(s), L(s); (r) signifiant rentrant, et (s) 
sortant. En effet. J appartient aux trois murs de devant, est sortant pour le 
mur 1, mais rentrant pour les deux autres. K et L étant de même nature, 
tout comme les deux derniers J, un premier dégrèvement mettrait dans la 
pile les points suivants : I, J, J, L. Mais ces deux J ne servent à rien Car, ici 
encore, aucun trait du mur grisé PORS n'arrive jusqu’à J. C’est pourquoi 
la ligne 1040 se charge d’éliminer ces deux points indésirables. Tous les 
points multiples seront ainsi gommés. Ainsi, l'encombrement de la pile 
principale sera réduit au minimum, et le tracé final plus rapide. 


Au total, on comprend pourquoi les trois schémas b;,b;,,b: de la 
Figure VII.B aboutissent tous au même indicateur: 2 (marqué en 
dessous). Chaque fois, des points indésirables sont ôtés, et c’est pourquoi 
ces cas de figure d’apparences si différentes (mais pas du point de vue du 
mur PORS, qui reste toujours avec deux coupures) aboutissent finalement 
au même résultat, à partir d’une pile provisoire très variable. 
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Ensuite, le programme cherche les intersections de la première verticale 
avec les autres murs. Deux cas très différents sont étudiés (lignes 1100 à 
1300). Tout d’abord, la première verticale peut être franchement coupée, 
comme l’est QS sur le schéma a. Dans ce cas, rien de bien spécial. 
Toutefois, notez que là encore on n’enregistre, de tous les points de coupe 
sur RP, que le plus haut (le plus proche de P), les autres n’ayant aucune 
importance. L’indicateur est alors positionné négatif, tout comme 
lorsqu'on trouve un point d’intersection sur la seconde verticale 
(lignes 1600 à 1700). Dans ces cas, le point d’intersection sur la première 
verticale, puis le point d’intersection sur la seconde verticale sont placés 
sur la pile p, à la suite des autres. Si l’une des deux verticales n’est pas 
coupée, on prend comme point d’intersection son point le plus bas (par 
exemple S pour la seconde). 

Mais, pour la première verticale, et pour elle seulement, un cas très 
spécial peut se produire, c’est le cas visible en b, : PR est aussi la première 
verticale d’un autre mur, le mur 1. C’est ici que le classement par ordre des 
verticales est essentiel, car si PR était la seconde verticale d’un autre mur, 
cela n’aurait aucune importance (cas des murs 1 et 2 sur b;). Par contre, 
ici, le programme risque de faire erreur. En effet, dans le cas du 
schéma b4, si l’indicateur est mis à 1 (un seul point sur RS), le programme 
va tracer de P à R et de R à I, ce qui ne doit pas être. Pour l’éviter, on 
ajoute dix à l’indicateur, et le programme de restitution, en ligne 3000, se 
charge du reste. Notons toutefois que cet ajout de dix exige un test 
(ligne 1210). En effet, en bs, le mur 1 a aussi PR comme première 
verticale, mais il est derrière, donc le mur PORS est complètement visible 
(indicateur à 100). Ce test porte sur le caractère plus ou moins incliné de 
l’arête inférieure (valeur de V;), la plus dressée vers le haut étant celle qui 
est invisible. Le schéma b4 donne encore un exemple différent de ce type 
de cas. 

Ainsi, nous voyons qu'après les calculs la valeur de l’indicateur et la pile 
vont permettre de tracer chaque mur correctement. Nous n’avons pas fait 
ici de grande théorie, mais uniquement de la pratique, basée sur une bonne 
observation des choses (et encore, on peut sûrement faire encore bien 
mieux). Mais la contrepartie en est que l’on doit traiter de nombreux cas 
particuliers (voyez la partie “Dessin”), ce qui n’éclaire pas tellement les 
choses. 

L'essentiel est bien sûr que le programme marche, sous quelques 
réserves toutefois. La première fut déjà dite : l'appartement doit être vu 
par le haut. Si thêta devient supérieur à 90, le tracé sera erroné. D’autre 
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part, les deux piles sont limitées. Pour la pile principale, ce ne sera guère 
gênant, je pense, mais cela peut l’être pour la secondaire. Il peut alors y 
avoir quelques problèmes. Dans ce cas, une bonne solution : raccourcissez 
vos murs. Préférez à un très grand mur deux ou trois petits les uns à côté 
des autres. De même, ne faites pas partir un mur du milieu d’un autre. 
Ainsi, si vous avez un T dans votre plan, il faut enregistrer trois murs: la 
barre verticale, la partie gauche de la barre horizontale, et la partie droite. 
Si vous enregistrez la barre horizontale en un seul morceau, la verticale 
partira de son milieu, et il se produira des erreurs. D’une façon générale, 
en cas d’erreur, subdivisez vos murs ; le tracé sera plus long mais exact. 

On pourrait encore, en travaillant sur quatre niveaux au lieu de deux, 
créer des portes et des fenêtres ; le principe général resterait le même. 
Enfin, le même genre de méthode s’applique pour les polyèdres concaves ; 
pour chaque arête, il faut calculer toutes ses intersections avec les autres : 
la longueur du programme, en lignes comme en durée d’exécution, serait 
telle qu’il n’en vaut vraiment pas la peine. Là aussi, il faudra s’adapter à 
l’usage que l’on peut faire de ces polyèdres.. ou utiliser un autre langage, 
plus rapide que le BASIC. 


3. LES FACES BOMBEES : SURFACES POLYNOMIALES 
— PRINCIPE DU TRACE D’HORIZON -— BORDURES 





Jusqu'à présent, nous avons essentiellement parlé de plans, pour toutes 
les surfaces que nous avons étudiées, ou de morceaux de plans (faces des 
polyèdres, murs...). 

Cependant, il va sans dire qu’il n’y a pas que des surfaces planes dans 
l’univers, bien au contraire. 

Les surfaces bombées peuvent, bien entendu, être représentées d’une 
manière approximative par des polyèdres aux très petites faces, mais la 
chose n’est guère élégante, car la surface est alors parsemée de traits qui 
n'existent pas en réalité. Or certaines surfaces s’en accommodent très mal. 

Il est possible de représenter des surfaces bombées sur un ordinateur, de 
deux manières différentes : avec, ou sans horizon. La seconde manière sera 
exposée au Chapitre IX ; nous allons traiter ici de la première. 


- 140 - 


f 
Le 
Mt LS 


Sphère (demie) Ellipsoïde (demi)  Hyperboloïde à une nappe 


ss O & 


Hyperboloïde à deux nappes Paraboloïde Cône 





Figure VII.C 


Comprendre ce qu'est l’horizon d’une surface n’est guère difficile. 
Lorsque vous regardez un ballon de rugby, par exemple (ellipsoide en 
mathématiques), vous en voyez la bordure ; au-delà de celle-ci, le sol, vos 
mains, l’environnement en un mot, sont visibles. A l’intérieur de cette 
bordure, vous ne voyez que le ballon, qui masque le paysage. Cette 
bordure, nous l’appellerons horizon, car l’horizon (au sens usuel) n’est 
jamais que l’équivalent de cette bordure, le ballon étant remplacé par 
notre planète, la Terre. 

Dans un cas comme dans l’autre, l’horizon est une entité artificielle, en 
ce sens qu'il s’agit d’une ligne imaginaire qui dépend, comme chacun sait, 
de la position où l’on se trouve. Néanmoins, cet horizon peut être tracé par 
votre ordinateur, pour certaines surfaces dites polynomiales. On peut 
également tracer l'intersection d’une de ces surfaces avec un plan qui le 
limite ; on peut ainsi tracer également une demi-sphère, etc. Le tout sous 
n'importe quel point de vue. 

Qu'est-ce que ces surfaces polynomiales ? Ce n’est pas compliqué non 
plus. D’une façon générale, une surface est donnée par une équation du 
type f(x, y,z) = 0, f étant une fonction donnée des trois variables x, y, z. 
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On dira que f est un polynôme s’il ne fait intervenir que des sommes, des 
produits et des puissances entières de ces variables. Par exemple 
x +x: y: 2/+3 est un polynôme, mais x : sin(y) n’en est pas un (à 
cause du sinus), non plus que z : y/x (à cause de la division). Vous l’avez 
deviné, une surface polynomiale a pour équation P (x, y,z) = 0, où Pestun 
polynôme. 

Pourquoi ces surfaces-là plutôt que d’autres (qui seront vues au 
Chapitre IX) ? Parce que ce sont les seules pour lesquelles on peut tracer 
simplement l'horizon. Toutes les autres exigent de très complexes calculs 
de dérivation, qui sortent complètement du cadre de cet ouvrage. (Voyez à 
ce sujet l'Annexe B.) 

Mais, me direz-vous, si je ne peux pas tracer n’importe quelle surface, je 
suis forcément limité. 

Eh bien, justement non. 


Imaginez, par exemple, que vous vouliez tracer un bateau. Même si c’est 
un bateau très simple, une barque, vous pourrez chercher longtemps une 
fonction donnant l’équation de la surface de la coque. Même en admettant 
que vous la trouviez, son seul énoncé complet serait si long que votre 
Amstrad risque alors d’être le premier ordinateur de l’histoire à se mettre 
en grève. 

Par contre, une barque peut être décomposée en gros en trois morceaux 
de coque : une paroi droite à l’arrière, le côté gauche (bombé), et le côté 
droit similaire, ces deux derniers se joignant au niveau de l’étrave, sur le 
plan de symétrie de la barque. Ces deux morceaux bombés peuvent sans 
difficultés être considérés comme des surfaces polynomiales (car ils sont de 
forme assez simple) limitées par deux plans : le plan de symétrie du bateau, 
et le plan de la paroi arrière. En traçant successivement ces deux morceaux 
de surfaces bombées, l’un contre l’autre, puis le bord de la partie arrière, 
vous obtiendrez ainsi votre barque d’une façon très réaliste. 

Or, de tels tracés sont possibles. Pas directement par le 
Programme VIL.2 qui ne peut tracer toutes les surfaces polynomiales. En 
effet, une surface polynomiale est caractérisée, comme son polynôme 
d’équation, par son degré (définition précise plus loin). Ce degré traduit, 
en gros, la plus ou moins grande complexité de la surface. Le degré 1 ne 
représente que les plans. Le degré 2, que seul permet le Programme VII.2, 
admet déjà un grand nombre de surfaces très variées (dont des exemples 
seront donnés en fin de chapitre). Naturellement, plus le degré est 
important, plus le programme correspondant doit être complexe, comme 


=,442.= 


nous le verrons. C’est pourquoi j’ai tenu à ne pas trop compliquer les 
choses avec ce programme, mais j’expliquerai néanmoins comment faire 
mieux, surtout dans l’ Annexe B. 

Avant de continuer, je dois encore parler de l'utilité de ces surfaces 
polynomiales. 

Nous avons étudié le tracé des polyèdres bien profondément. L’inconvé- 
nient des polyèdres tient en une phrase : leur faces sont plates, donc ils ne 
collent pas très bien à la réalité. 

Qu’à cela ne tienne. Nous leur donnerons des faces bombées. Vous 
devinez de quel type: polynomial... D'abord de degré 2 puis, si cela se 
révèle nécessaire, de degré supérieur, suivant l’objet à imiter. 

Je ne donne pas là les intentions de cet ouvrage, car j’en outrepasserais 
alors le cadre, mais celles qui furent probablement les premières des 
inventeurs de la C.A.O. (Conception Assistée par Ordinateur). En effet, 
c’est ainsi que les ordinateurs puissants destinés à cet usage créent avions, 
navires, automobiles sur leurs écrans, images somptueuses dont vous avez 
probablement vu des exemples à la télévision ou dans des magazines. 

Cette création, si vous assimilez ce qui va suivre et si vous avez bien 
compris les problèmes posés par les polyèdres, vous sera tout à fait possible 
à condition que vous soyez courageux, patient, et un bon programmeur 
d’assembleur car seul ce langage pourrait permettre une vitesse correcte 
d’exécution pour des objets compliqués ! 

Avant d’en arriver à ces multiplicités de faces bombées, essayons déjà 
d’en tracer une seule, cela suffira à notre plaisir. 

Expliquons déjà ce qu’est le degré. Un polynôme de trois variables, 
formant l’équation d’une surface polynomiale, est la somme d’un certain 
nombre de monômes, du type a : x“: y” : z", où a est une constante 
quelconque, et u, v, w trois entiers positifs. La somme s = u + v + w de ces 
trois entiers est appelée degré du monôme. Le degré du polynôme est le 
plus grand de tous les degrés des monôêmes qui le constituent. Par exemple, 
si le polynôme est 


Z 
P(x,y,2)=4:x-ÿ-y:z +2 
nous y voyons trois monômes : 
Z 
Cr 
Dans le premier, on a: a=4; u=1; v=2; w=0 (un nombre à la 
puissance zéro vaut 1), donc s=3. Dans le deuxième: a=-—1; 


nr 


1/8 = 0,125 ; u = 0; 


u=3;v=1;w=1,doncs=5. Dansle dernier: a 


v=0; w=1; doncs=1. La plus grande valeur de s est obtenue pour le 


deuxi 


= 5. Nous dirons que P est un polynôme de 


\ 
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éme monome, ou ss 


à 


degré 5. 
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Ssszess=es2ez==sss=====e=sz==s SURFACES FOLYNOMIALE DE DEGRE 2 
=== ENTREE DES DONNEES. INITIALISATION 








36 MODE 1:INK @,G:EBORDER G:INK 1,24:INK 2:6:PEN 2 

49 PRINT THECS),"ENTREE DU POLYNOME" : PRINT : PRINT 

Sà FEN 1:DInm PS3) 

68 INPUT "Terme constant ";PCG):PRINT 

74 INPUT "Terme en x ";PC12:PRINT 

84 INPUT "Terme en y ";PC2):PRINT 

38 INPUT "Terme en z ":PC3D:PRINT 

196 INPUT "Terme en x#x ":PC45:PRINT 

119 INPUT "Terme en #Xy ";PCS2:PRINT 

126 INPUT "Terme en z*#z "i5PC6): PRINT 

139 INPUT "Terme en xXs ";:PC7): PRINT 

148 INPUT "Terme en x*z "3PC32: PRINT 

158 INPUT "Terme en 4#%z ":3PC9D: PRINT 

164 CLS PEN 2 

179 PRINT TABCS). "PLANS LIMITES" :PRINT:PRIHT 

139 PEN 1:INPUT "Nombre de Plans limites "in 

136 PRINT:PRINT"'Entrez les coefficients des equations""des Plans limites 
sous la forme :""u#kx+v#ks+uxz+k=g" 

244 PRINT:CIM Plén, 3) 

219 FOR t=1 TO n 

224 PRINT:PRINT"Equation du Plan numero "t:PRINT:PRINT 

259 INPUT;"u "ou: INPUT": vw iv: INPUT; "5 w "ou: INPUT; "5 KO "ik 
hi RES AE R ER ERP IE RTE ES ER ORNRES ER 
25 T 

264 CLS : INPUT "Precision du trace "ih 


AD AO 9 9 Ui 00 0 
Biol © à 





==2=22 Calcul des coefficients differentiels 





3 CIM 46n:5) 


FOR t=i TO n 
d=-Plét:3) 


G qCt,:G)=pPC G+PlCt. BOkCPC IPC EIKPLCt,D3/d)2/d 





SGSoSuu 


ACt:1)=PC1I+PICt. 12KCPC3D+2XP LCL, GokPCé)/d2/d+P lt, GokPC Sd 
qét:2)=PpCzD+Plét, 2okCPCS2+2%P lt, GokPC 6) /d2/d+plét, BokPC33-d 
t,32=p€ 4)+P1Ct. 12#CPCS2+PC6 DEP lt, 123/d2/d 
CSD+PICt, ZokCPCG+PCE KP lt. 23/d2/d 
PCT D+PICt, ZDKCP +2#P1Ct,12#PC62/d2/d+plét, 13#P6 32/4 
=1 _THEN RETURN 














= Calcul du Point initial 
s45:w=46 1,55 





: 1:23: u=1C 1,3 401 
aazuku-dt4u : bh=ukb-2tvkta : co=btb-4kvkc 
IF cc>=ÿ THEN xi=@:GOTO 56@ 

IF 3a2=4 THEN xi=-bb/3a:GOTO 5684 
xi=2#ABS( bb/aa 2) 

IF v=4 THEN yiz-(c+xi#(a+xi#u)2/Cutxi+b):GOTO 554 

IF wkxi+b=@ THEN s1=S0RC-Cc+x1#C a+x1 #0 3/42: GÛÜTO 5364 
H1=C SRE Cukx1+b)2-4HVKC C+x DK ax LU 2 12-Cukxi+b ur E 





zi=-CP1C1,92+xi%P 1 1,12+31#P161:292/P161:32 


INPUT "Echelle "ie:CLS 
DIM signçn)2:DIM Frod(n) 
DIM rac(1@.4 


INPUT "Anale Psi “ipsi 

FRINT:PRINT: INPUT "finale theta "itheta 
CLS 

ng=COSCPsi)#SINCtheta) 





coefficients d'horizon 










DS theta ) 

nBkPCB+nIXPCG)+2#n2#kP 6): IF PlCG,353<0.G@1 THEN P1(9,32=8. 401 
P1C@:9)=n@#P< 1 2+niX#PC22+n£#Ppc 3) 

P1CG:12=2#n@#4Pt 4)+n1#kPC7D+ne#kPe 8) 

=ngxPe 7 )+2#n1#PCS)+n2kPt 9) 


Recherche du Point de depart 





t=1:h=18th 
IF indic=1 GOTO 1908 


GCOSUB 1:66 :GOSUB 2559 
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356 GOSUE 12698:IF indic=1 GOTO 1548 
369 GOTO 34% : 

193% lRSSSSSSS=E=====SSSSESS SSSR SRESESSSS=Z== ZE SEE DESSIN CRoutine PrinciFale) 
1919 xd=x:ud=y:zd=z 

1828 h=h/19:Prodÿ=1:divh=1 

1936 MODE 2:INK 1.:26:ORIGIN 325,298 

1949 GOSUB 1499:PLOT XX,7% 

1954 j=g 

ee à FOR u=g TO n:signu2)=SGNCPlCu, Gi+plou, 12#x1+Pl0u. 23449 i+PlCu, 3I#Zi 2: 
NEXT 

1979 signé 1i=1 

1289 GOSUE 1399:GO0SUB 2564 

1994 FOR u=ÿ TO n:prodiudï=sign(u)#Cr lou, @2+plCu, 12#kx+PlCU, 2 3#4+PlQu, 34zD: 
NEXT 

1198 FOR u=@ TO n 

1116 IF uit THEN GOSUB 1454 

112G HEXT 

1139 IF Cx-xd)4kCx-xd+éy-sdi#(u-sadi+éz-zdik(z-zd<h#th/2 GOTO 2854 

1148 GOSUB 1463 

1154 DRAM XX, 7% 

1168 COSUB 1399:GOSUB 2598 

1179 GOTO 1194 

1209 ’=xzzs==2sss=2 =zsz= [est de visibilite 
1218 indi l {9:3)) 
1229 RETURN 







Point suivant 





J4= : 
Ets S+ekSHACE, 4+x#AC Lt, 55 

Cat. 1+2kx#kaCt, 3+y#90t, 55) 
dxk#PlCt,10+du#plét.2))/plét,3) 













#dx+da#tdy+dz#dz : r=SÛRC r 2 
1569 x=x+hkdx/r 

1379 3=3+h4dy/r 

1389 z=2z+h#dz/r 

13936 RETURH 


== Coordonness Proietees 






(S ET INR DHCOSC Eat DV 0 


1438 RETURN. 
Routine de si3nes 








1474 É roue 5 i gré y) 

1454 IF RE: Prod ABS hkdivh/208 ? GOTO 1500 
1436 IF Prod#Pr 
divh=-2*#divh:Pr 














KA 5 à 
1529 KCEX: Joy: IF. RES L Re, 32% 
J#Pleu. 2)3-PlCu 3) 


Kk#P LOU: 1 3+ 


GOSUR 1349: Re 
1558 tzud:x=xc:y 

1564 uetg: S=Pl(u,9 Hi U:2)#s+PlU, 32#z)#ksi3nct9) 

HSF6 IF s<s6 THEH sous: ha-h: Fa=-fg:xexciyayc:z=zc: COTO 1554 

1528 GOSUE 1443 

1599 IF uM<>9 AND t9<>6 THEN DFAU KK:YY:GOTO 1668 

1689 Past KkC-HKO IEC AA -KRRE DEC VV EYE TKCTT-V TE D 

1618 IF tü=à4 COTO 1694 

1629 IF Ps>Q AMD indicz=-1 THEN x@=xc:uÿ=uc:zÿ=zc:f9=1@:GOTO 1658 

1639 te=t@:GOSUB Z1G4:1F farac>=@ COTO 2208 

14 x=xciy=sc:z=zc:h=fg#h 

1654 ract j,@)=xc:rac( j,1)=sciracc j,2)=zciract i.3)=fgiracc ji, 4)eud: j=i+1 
1668 GOSUB 1394 

1678 FOR u=g TO n:Prod@u)=signéu2D#Cplou,D24P lu, 1 2Xx+P LCu, 2 


1 kx+P lu, TDks+P lou. T#2z0: 58970 









Xks+P lou, 32#z 2: 


1559 RETURN 

1638 IF PS>9 THEN indic=-1:COTO 1628 

1788 t=t@:GOSUR 21@0:f3=-1 :h=ABSC HD: divhel :tzug 
1714 ee faracc GOTO 1644 ELSE 2268 


2414 IF i=ÿ GOTO 3989 
2928 j=j-1 
2939 xærac( j,Q5:y=racct ji, 1:z=ract i,2) 





Raccordement 
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2448 

















OSUE 1396 


+ LC 1 oc+r LOU, 2 Eu+P LOU, S 





Test d'egalite des raccords 





2114 FÜR 


2124 IF (x-racçu, 8)" 2+Cy-ractus 122 2+6z-raciu. 232" 2<hkhkdé THEN faracau: 
RETURN 
2138 NEXT 
assssrssseesssssecsszss (ter Un Point de raccord 
: ! TO diraccu, wi 2=ract ut, wu 2: NEXT 
2234 NEXT:j=j-1 
Calcul du Po 






au Foint 
+ 





P=PCD)+PC1DKkx+PCZDKI+PC 
DHXKZHP( TOI4SKZ 

2329 RETURN 

2508 ’==z=zzzz2mzz2z-22zszsssssssssses=ss=sssssss=sessssssss Test Polsnomial 

2516 GOSUE 2369 

2524 IF ABSCP ><G.95 THEN RETURN 

2539 x=xÿ: 


HX+P CS DK HS +P CG IEZHZH+P( 






== Correction 
2619 GOSUB 2365 :P@=P 

2629 9=-9.1#S5SGNCP à 

2634 HNG=PC 1 +2%XxX4P C4 D+Y#PC 7 D+ZKP(S 2 

2649 HNI=PCZ)+2#4#PCSD+XKPC 7 +2z#kP( 90 

2659 NHZ=PC3)+24Z#PCE )+xKkP CS )+Y4P C3) 

2669 x=x+9#NNQ : 5=3+9%NN1 : z=z+3XNNZ: COSUB 2345 

2678 IF AESCP 6.695 THEN RETURH 

2688 IF P*xPA<G THEN 9=-9/2 

2699 PQ=P :GOTO 2669 

3099 ‘’========22=222222222-RSR22S22S2SELSESSESSSSSESSSESSSSSSSESSSESRERESSSES FIH 
3419 PRINT CHR$7) 

3929 WHILE INKEY(47)=-1 AND INKEY(793=-1 AND INKEY<S3 )=-1 : HEND 

3939 IF INKEYC(472<>-1 THEN MODE 1:INK 1,24:PEN 1:GO0TO 768 

3948 IF INKEY(792<>-1 THEN RUN 

3959 IF INKEY(S32<>-1 THEN MODE 1:INK 1:24:PEN 1:INK G,1:BORDER 1:END 


EEEEEEEEEEEEEEEEELELEÈEÈEÈELELELELEZELZLEZEZEZEZEZEZEZEZEZEZEZE—— 


Évidemment, plus le degré est élevé, plus le nombre de monômes 


possibles est important. Ainsi, pour le degré 0, un seul mônome est 
possible : u = v = w =0, donc pas de x, ni de y, ni de z ; la constante a est 
toute seule, c’est le terme constant. Pour le degré 1, seuls trois monômes 
sont possibles : a : x; a: y; a : z. Un polynôme de degré 1 est du type: 
a:x+b:y+c:z+k=0 (a, b, c, k, quatre constantes); c’est donc un 
plan, la surface la plus simple. Enfin, il peut y avoir six termes de degré 2 
(voir lignes 100 à 150 du programme) : un polynôme de degré 2, ayant des 
monômes de degré 0, 1 ou 2, a donc dix monômes différents, qui sont tous 
précédés d’une constante. Dans le programme, ce sont ces dix constantes 
qui sont demandées en lignes 50 à 160, et stockées dans une petite 
matrice p. Par exemple, si vous voulez rentrer l’équation d’une sphère de 
rayon 1, soit 


x?+y?+z2—-1=0 
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vous devrez rentrer dans l’ordre : — 1,0,0,0,1,1,1,0,0,0. 

Ensuite, on demande les plans limites. Ce sont des plans où la surface 
sera arrêtée. Le programme tracera aussi l’intersection de ces plans avec la 
surface, dans leur partie visible (s’il y en a une). Ces plans sont nécessaires 
en général, car les surfaces polynomiales sont presque toujours infinies, au 
moins dans une direction. C’est dans cette (ou ces) direction(s) qu’il faudra 
mettre un plan qui arrêtera la surface, sinon le tracé va sortir de l’écran. Le 
programme (lignes 170 à 250), demande de rentrer l'équation du plan sous 
la forme u:x+v-y+w:z+k (u,v,w,k étant quatre constantes 
quelconques). Toutefois, pour des raisons que nous expliquerons plus loin, 
vous ne devez pas entrer Ü pour w, sinon un message d’erreur se 
produirait. 

La précision du tracé est demandée ensuite. En effet, le tracé des 
courbes se fait d’une manière approximative, en traçant de petits bouts de 
droite successifs ; h représente la longueur de ces petits bouts. La courbe 
aura bien l’air d’en être une si h est très petit (0,01), mais le tracé sera plus 
long. Cela est complètement général, quelle que soit la courbe tracée, 
plane ou de l’espace, etc. (voir Annexe A). Ici, h—=0,05 convient en 
général. 

Toujours expliquant le programme, je passe pour l'instant sur les 
coefficients différentiels pour arriver au calcul du point initial. En effet, le 
tracé de toutes ces courbes (horizon + intersections avec les plans limites) 
se fait point par point (comme pour toute courbe), c’est-à-dire que chaque 
point est déduit du précédent, comme nous le verrons dans un moment. Il 
faut un point de départ (éternel problème de l’algorithme et de l’amorce). 
Ce point de départ sera lui-même déduit d’un point initial, calculé une 
bonne fois pour toutes (lignes 500 à 600). Ce point est calculé sur le plan 
limite 1 (qui existe nécessairement de ce fait). Si ce plan a pour équation 
z=À:x+u:7y+uv,en remplaçant z par sa valeur (fonction de x et de y) 
dans l’équation de la surface, on obtient une équation du second degré en x 
et y, du type: 


u-+v-y+w-x-y+a-x+b-y+c=0 
où u,v,w,a,b,c sont six constantes calculées par le programme 
(ligne 510). Je ne m’étendrai pas sur la résolution de cette équation, qui 
aboutit à des équations du second degré et d’une variable, du type: 


aa: y+bb:y+cc=0 
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dont la résolution est aisée. Mais songez que si la surface était de degré 
supérieur, l'équation ici le serait aussi, et le calcul du point initial serait 
assez compliqué (résolution pratique nécessaire : voir comment résoudre 
une équation de manière approchée plus loin). C’est une des raisons pour 
lesquelles je me suis limité au degré 2. La seconde ne va pas tarder à 
apparaître. Je dois pour cela expliquer comment l’on peut tracer l’horizon 
d’une surface polynomiale. 

En un point donné d’une surface, mettons M, de coordonnées (x, y, z) 
(vérifiant l’équation de la surface, évidemment), on peut presque toujours 
définir un vecteur normal à la surface. C’est le vecteur normal au plan 
tangent à la surface. Pour vous représenter ce plan, imaginez que vous ayez 
fabriqué un modèle en bois de la surface. Sur ce modèle, vous faites une 
croix au crayon au point M. Vous prenez ensuite une petite planche carrée 
(et plane), et vous la clouez sur la surface, exactement au point M. Eh 
bien, le plan de cette planche, qui collera au plus près à la surface, est 
confondu avec ce que l’on appelle le plan tangent à la surface. Sa 
perpendiculaire (le clou), porte le vecteur dit normal à la surface, qui est 
dirigé dans le sens inverse du clou, de façon à avoir l’air de sortir de la 
surface (comme pour les polyèdres). Tout cela est résumé par le schéma a 
de la Figure VII.D. Voyez aussi l’ Annexe A à ce sujet. 
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Figure VII.D (a) 
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Figure VII D. (à) nono 








Le vecteur normal en un point est calculable. Ses coordonnées (p,q,r), 
sont les dérivées partielles de l’équation de la surface, respectivement par 
rapport à x, à y et à z (pour plus de précisions sur ce point, voir l'Annexe A 
sur la dérivation). 

D'autre part, nous connaissons les coordonnées (vo, V1, v2) de la normale 
V à l’écran. Ces dernières, à la différence de p,gq et r, sont immuables car 
elles ne dépendent que des deux angles psi et thêta du point de vue. 

Un point est sur l'horizon si la normale en ce point est perpendiculaire à 
la normale à l'écran, c’est-à-dire si leur point scalaire est nul. L’horizon H 
a donc pour équation : 


Vo'p+"'q+v'r=0 


où p,g, et r sont en fait des fonctions de x, y, z. Ces fonctions sont aussi des 
polynômes, de degré égal au degré de la surface moins un. C’est pourquoi, 
pour des surfaces de degré 2, cette équation de l’horizon est de degré 1; 
c’est donc l’équation d’un plan. C’est là la chose fondamentale, propriété 
essentielle du degré 2: l’horizon est sur un plan, comme pour les plans 
limites ; ce sera le plan limite zéro, dont les coefficients sont calculés aux 
lignes 770 et suivantes. 


Si la surface était de degré supérieur, l'horizon ne serait pas contenu 
dans un plan, et le tracé en serait un peu plus complexe ; c’est la raison 
pour laquelle je me suis limité au degré 2 dans ce programme quoique, en 
réalité, ce ne soit pas obligatoire (voyez l’ Annexe B). 


Encore un mot sur cette définition de l’horizon par un produit scalaire. 
Elle ne doit pas vous surprendre. En effet, souvenez-vous que pour les 
polyèdres, lorsque le même produit scalaire était nul, la face était vue par 
la tranche ; elle était alors à la limite du polyèdre. Ici, c’est le plan tangent 
qui est vu par la tranche, car le point M est à la limite de la surface, sur 
l'horizon (voir Figure VIL.D, schéma b). C’est pour la même raison que le 
test de visibilité (lignes 1200 et suivantes) consiste à chercher le signe de ce 
produit scalaire. La différence principale réside dans le fait que ce produit 
scalaire change à chaque point, alors que pour les polyèdres il changeait à 
chaque face. Mais en fait, une surface bombée est une sorte de polyèdre où 
chaque point est une minuscule face. 

Précisons toutefois, une fois encore, que l’horizon pourrait très bien être 
tracé, même pour des polynômes d'ordre supérieur. Expliquons tout de 
suite comment votre ordinateur va pouvoir tracer l'intersection de la 
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surface d’équation P(x,y,z) =0 avec un plan (plan limite) d’équation 
a:x+b':y+c:z+k=0. 

Tout d’abord, cette dernière équation doit être convertie, sous la forme 
X=.., Y=... OU Z=.…, Suivant que 4a,b ou c est non nul. Ici nous 
supposerons que c n’est pas nul. Alors on peut écrire : 


>= Gr by ER) 
(— c) 


Reste alors à remplacer z par sa valeur dans l’équation P(x,y,z) =0, 
pour obtenir une équation du type Q (x, y) = 0, où Q est aussi un polynôme 
de degré 2. Par exemple, si P(x,yz)=x:y+4-y+6+y:2z+7:7,et 
que le plan limite a pour équation — x +z—3—0, c’est-à-dire z=3+x,on 
remplace z par 3 + x et l’on obtient: 


Q(x;,y)=x: y+4:y+6+y:(3+x)+7:(3+x) 
exp: y+ECES Ex y+1+7:x 
soit : 
Q(x,y)=2-x y+7:x+7:y+27 


qui est un polynôme en x et y d’ordre 2 aussi. D'une façon générale, un tel 
polynôme a six termes : constant, en x, en y, en x?,en y?, en x : y. Ils sont 
ici égaux à 27,7,7,0,0,2. Pour chaque plan limite, le programme calcule 
ces termes aux lignes 300 et suivantes. Y compris pour l'horizon, ici 
considéré comme le plan limite zéro (ce ne serait pas possible pour un 
degré plus important, qui exige une double résolution d’équation 
implicite). 

Cette équation Q (x, y) = 0 est appelée équation implicite en x et y. Pour 
le détail de sa résolution point par point, le lecteur se reportera à 
l'Annexe B. Cette résolution est ici exécutée par le programme aux 
lignes 1300 et suivantes : à partir d’un point, sur l’un des plans limites, le 
programme peut trouver le point suivant sur la courbe, située à la 
distance h. Les courbes, intersections des plans limites et de la surface 
peuvent donc ainsi être tracées. 


C’est ce que fait le programme. Partant du point initial, il cherche, sur la 
courbe C;, intersection du plan limite 1 (P1,) avec la surface S, le premier 
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point qu’il trouvera visible (test de visibilité en 1200, d’après le fameux 
produit scalaire). Ce point, qui est souvent le point initial lui-même, est 
appelé point de départ. En effet, c’est à partir de lui que tout commence. 
On le place sur l’écran, après avoir calculé ses coordonnées projetées XX 
et YY (toujours les mêmes formules...). Puis on cherche le point suivant, 
on le place, et on recommence. 

Deux cas peuvent faire changer cette routine. Tout d’abord le retour au 
point de départ (obligatoire en principe, sinon c’est qu’il manque un plan 
limite). On passe alors à d’autres tracés, s’il y a lieu, comme nous le 
verrons. Second cas, très important celui-là, le changement de plan limite. 

En effet, les courbes Co, C1, C>, …, intersections des plans limites avec la 
surface, se rencontrent en général entre elles et c’est heureux, sans quoi il 
serait difficile d’aller les tracer. Il faudrait en effet recommencer le même 
travail que pour le plan 1 (calcul du point initial), travail déjà pas simple, 
mais absolument abominable pour des degrés supérieurs. Comment savoir 
si le point où l’on se trouve n’est pas tout proche d’un autre plan limite ? 
Tout simple, il suffit d'appliquer l’équation de ce plan au point, et l’on 
obtient la valeur s (ligne 1460). Si s est nul, le point est sur le plan, mais 
cela n’arrive jamais ; le point est en fait, au mieux, tout près du plan ; s est 
alors très faible et cela suffit (les tracés de courbes sont de toute façon 
toujours très approximatifs). 

Une précision sur le signe de s : selon qu'il est du même signe que le s du 
point de départ (signe stocké, pour chaque plan limite, dans la matrice 
sign) ou non, le point considéré est du même côté que le plan (alors prod 
est positif), ou du côté opposé (alors prod est négatif). 

Conclusion: lorsque prod change de signe, ce qui se traduit par 
prod : prod (u) négatif, c’est qu’on a traversé le plan limite n° w. Dès lors, 
il ne faut pas tracer, mais rechercher le point intermédiaire, qui est à la fois 
sur la courbe t (que l’on était en train de tracer) et sur la courbe u. Ce point 
est le point de raccord entre les deux courbes. On en trouve la valeur 
précise en oscillant autour, en diminuant h pour faire des pas de plus en 
plus petits. Le point est enfin (pratiquement) trouvé lorsque prod est petit 
(ligne 1480). On part alors vers une routine spéciale qui traite les points de 
raccord. 

Il existe deux types principaux de points de raccord: les raccords 
immédiats, et les raccords reportés. Dans le cas des premiers (voir 
Figure VII.D, schéma c 1), deux courbes aboutissent au point de raccord, 
mais n’en repartent pas, en ce sens que leurs prolongements au-delà de ce 
point sont soit cachés (car les parties cachées sont pour l’essentiel non 
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représentées), soit au-delà d’un plan limite donné. Or, l’on ne représente 
que la partie de la surface qui se trouve du même côté que le point de 
départ par rapport à chacun des plans limites. Lorsqu'une courbe €, 
traverse le plan L,,, le point d’intersection, étant à la fois sur C,, donc sur la 
surface, et sur L,,, se trouve sur C, : c’est bien un point de raccord entre les 
deux courbes C, et C,,, et l’on passe alors de l’une à l’autre dans le tracé, 
d’où le nom de changement de plan limite qui a été donné à cette routine. 


Malheureusement, ce nom devient injustifié lorsqu’on se trouve dans le 
cas d’un raccord reporté. 


Ce genre de cas peut se produire lors de l’intersection de l’horizon avec 
une courbe d’un plan limite L, ou (dans des cas exceptionnels) entre deux 
plans limites. 


C’est surtout avec l’horizon H qu’il y a des problèmes. Examinons en 
effet la Figure VIL.D, schéma c, n°® 2 à 4. En 2, que voyons-nous ? Le 
tracé arrive par L (suivre les flèches), puis rencontre l’horizon H; la 
courbe de L disparaît derrière la surface après cette rencontre. Le tracé 
doit donc se poursuivre sur H, en abandonnant L. En 3, le tracé arrive sur 
L, rencontre l'horizon, mais doit se poursuivre car L n’est pas dissimulée 
derrière la surface au-delà. Il en est de même en 4. 


C’est pourquoi le programme doit procéder à des tests. Examinez la 
partie agrandie de 2 (dans le grand cercle). Arrivant de M, (coordonnées 
projetées XX0, Y YO), la courbe arrive en R, point de raccord (après une 
recherche dont nous avons déjà parlé, et dont nous reparlerons). Sur L 
toujours, après R (coordonnées projetées XXc, YYc), il y a S (calculé en 
ligne 1540 dans le programme). Pour S, le flag indic montre si ce point est 
visible (c’est-à-dire sur la partie avant de la surface) comme dans le 
schéma c4, ou invisible comme dans les schémas c2 et c3. Observez bien en 
effet, dans ce dernier cas, que la partie de L située au-delà du point de 
raccord est visible en pratique (c’est-à-dire qu'il faut la tracer), mais 
invisible en théorie, car derrière la surface ; la différence vient de ce que 
toute la partie de la surface qui masquait ce second morceau de courbe se 
trouvait en dessous du plan de L, et par conséquent a été en quelque sorte 
arrachée, enlevée. 


Mais R appartient aussi à H. Sur H, il y a deux points suivant R : P et P’, 
suivant la direction dans laquelle on va. Des deux, il faut choisir celui qui 
se trouve du bon côté du plan de L (au-dessus dans les cas de figure), soit 
P ; cela est fait aux lignes 1550 à 1570. 
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Ensuite le programme examine l’angle séparant MR de RP. Si cet angle 
est aigu (cas 2 et 4), le produit scalaire ps de ces deux vecteurs est positif, 
sinon (cas 3) il est négatif. 

Il suffit de regarder les cas de figure pour constater qu'il faut à la fois que 
S soit invisible (cas 2 et 3) et que ps soit positif (cas 2 et 4) pour que l’on 
puisse effectivement passer d’une courbe à l’autre (cas 2). Dans les autres 
cas (3 et 4), le point de raccord R est enregistré dans une matrice spéciale 
rac: lorsque le tracé sera fini (retour au point de départ), la routine 
raccordement se chargera de faire repartir le tracé de ce point de raccord. 

Précisons d’autre part que, de toute façon, R sera enregistré (mais avec 
fg = 10 au lieu de fg = + 1), afin que si le tracé, par hasard, venait à revenir 
en ce point, il soit stoppé (car il est douteux que quatre courbes se 
rejoignent au même point; le tracé se recopierait donc, sans cette 
précaution). 

Voilà l'essentiel de ce qu'il fallait dire au sujet de cette routine 
changement de plan limite, et de ses auxiliaires, les trois suivantes. Notez 
simplement que j est le pointeur de rac, qui sert de pile ici. 

Cependant, vous n’avez peut-être pas très bien compris comment l’on 
trouve une valeur assez exacte du point de raccord. Si c’est le cas, je vous 
propose de le développer plus en détail, en expliquant une autre routine 
effectuée pour chaque point en ligne 2500. Cette routine a en effet valeur 
d'exemple puisqu'elle est le modèle classique pour trouver la solution 
d’une équation. 


Pour un point donné (x, y,z), la valeur p = P(x, y, z) est calculée par la 
routine en ligne 2300. Idéalement, puisqu'on trace la surface d’équation 
P(x,y,z) = 0, on devrait avoir constamment p = 0. 


Malheureusement ce n’est pas le cas, et rien ne peut y faire. En effet, on 
ne peut tracer ce genre de courbe ou de surface qu’approximativement. 
Conséquence, p n’est pas nul. Pire même: au fur et à mesure que l’on 
trace, les petites erreurs de calcul qui se produisent à chaque fois 
s'accumulent, tant et si bien qu’on finit par dépasser les bornes du 
tolérable ; p devient, en valeur absolue, supérieur à une valeur déjà plus 
tout à fait très petite : 0,05 (ligne 2520). Que faire alors ? Une correction 


(lignes 2600 et suivantes). 


Examinons le schéma d (toujours de la Figure VII.D). En haut, la 
surface est vue par la tranche. Elle est accompagnée de sa normale N. 
Cette normale a été représentée encore quatre fois en dessous, pour ne pas 
surcharger la figure. 
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Lorsque cette routine est appelée, (x,y,z) sont les coordonnées du 
point 1. Ce point étant jugé trop éloigné de la surface, on va tâcher de le 
recentrer en le replaçant tout près de la surface, dans la zone grisée où p 
est, en valeur absolue, inférieur à 0,005. 

Pour cela, on va se déplacer sur la normale, à une distance g. Notez que 
la surface partage l’espace en deux parties : d’un côté (ici à droite) p est 
positif, de l’autre il est négatif, et nul sur S, bien entendu. Il faut rendre p, 
en valeur absolue, le plus petit possible. Ayant calculé p au point 1, si p est 
positif, il faut le diminuer (d’où g négatif), et sinon l’augmenter (g positif), 
afin, dans tous les cas, de le rapprocher de la valeur parfaite : zéro. Donc, 
en ligne 2620, g est initialisé avec le signe inverse de p, à — 0,1 dans le cas 
de figure (g est indiqué à gauche de la figure). 

On calcule alors le point suivant sur la normale, et l’on arrive au point 2 
(ligne 2660). On voit que 2 n’est pas dans la zone grise (ligne 2670), il faut 
donc continuer. D'autre part, p, en 2, est du même signe que p, en 1. Il 
faut continuer à le diminuer. On arrive ainsi en 3, sans que g ait changé. 

Arrivé en 3, p est devenu négatif. Il faut donc l’augmenter, donc changer 
le signe de g. Mais ce n’est pas tout. Si l’on ne fait que cela, on va revenir 
en 2, puis en 3, puis en 2,... 

Le truc consiste alors à diviser g par deux. g vaut alors 0,05 (ligne 2680). 
On arrive en 4, p reste négatif. On passe en 5 où p redevient positif (5 est le 
même point que 2). On repart dans le sens inverse, non sans avoir divisé g 
par deux et avoir changé son signe. On arrive alors en 6, et remarquez que 
l’on se rapproche de plus en plus du centre. En 6, p devient négatif. On 
redivise g par deux, on change son signe, et l’on arrive en 7 qui se trouve 
dans la zone grise : c'était le résultat recherché. Il n’y a plus qu’à repartir de 
7 pour continuer le tracé. C.Q.F.D. 

Sur le dessin, la différence entre le point 1 et le point 7 est infime, mais 
elle est essentielle, sinon le programme se perdrait rapidement. 

Notez toutefois que toute cette correction ne s’effectue pas tout à fait sur 
la même droite, car les coordonnées du vecteur normal sont recalculées en 
chaque point pour aboutir plus rapidement. 

Retenez ce raisonnement, car c’est le raisonnement de base pour 
trouver, de manière approchée, la solution d’une équation. Il en existe 
beaucoup d’autres, plus ou moins subtils, mais celui-là est indispensable. 
Voyez à ce sujet l’ Annexe B. 

Il ne vous reste plus guère qu’à tester le programme avec les exemples 
qui vont suivre. Je dois simplement vous préciser deux points de détail. 
Tout d’abord l’échelle est un coefficient multiplicatif qui permet de rendre 
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plus ou moins grand le dessin. Si vous ne voyez qu’un petit tas, agrandissez 
sa valeur (vers 50), sinon diminuez-la. D’autre part, lorsque le tracé est 
fini, vous entendez un bip sonore. Alors, si vous appuyez sur f (comme 
fin), tout s’arrête (ligne 3050). Si vous appuyez sur DEL, tout recommence 
au début. Si vous pressez la barre, vous retournez en 700 choisir de 
nouveaux angles pour changer le point de vue. 

Toutefois, avant de donner les exemples les plus significatifs, je dois 
vous mettre en garde. Le programme ne marchera pas dans tous les cas, 
tant s’en faut. Il lui arrivera assez fréquemment de se “planter”, d’une 
manière ou d’une autre. 

Les deux plus courantes des erreurs seront celles-ci. Soit le tracé s’arrête 
et ne reprend pas. C’est que le programme boucle entre la correction et le 
passage au point suivant. Soit le tracé passe à côté du point de départ sans 
s'arrêter : l’erreur, au niveau de l’équation des plans, est devenue trop 
importante. Dans un cas comme dans l’autre, la solution la plus efficace est 
de diminuer la précision du tracé ; recommencez en la divisant par deux. 
Dans le second cas, toutefois, un simple changement des angles peut 
suffire à régler le problème, et c’est tant mieux car diminuer h revient à 
augmenter la durée du tracé. 


D'autre part, il peut arriver des problèmes par votre faute : le choix des 
plans limites n’est pas toujours facile. En effet, il est nécessaire que le 
premier rencontre la surface ; il faut donc en être sûr. Même si c’est le cas, 
le tracé peut sortir de l’écran et ne pas revenir ; c’est qu’il manque un plan. 


Enfin, un problème qui n’a pas de réelle solution : les points anguleux. 
Ce sont les points (heureusement très rares) où il n’existe pas de plan 
tangent. C’est le cas notamment de la pointe des cônes. Dès lors, il peut 
arriver (pas toujours) des ennuis au moment où le tracé arrive en de tels 
points. N'oubliez pas, en particulier, qu’il n’y a pas de vecteur normal à cet 
endroit, d’où problème... Là encore, la diminution de h peut être le 
remède salvateur. 


Et puis, il peut arriver quelque chose que je n’ai pas prévu. Cela ne m'est 
pas encore arrivé, depuis que ce programme est au point (dans la limite de 
ses possibilités). Dans ce cas, essayez encore la même méthode si cela se 
produit, ce que je n’espère pas. Mais, en tout état de cause, pas d'illusions, 
ce programme n’a rien de miraculeux. Par contre, il peut tracer sans aucun 
problème des morceaux pas trop grands ni trop difformes de surfaces 
bombées, or c’est cela sa véritable utilité, si vous vous souvenez de ce que 
j'ai dit sur la C.A..O. 
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4. EXEMPLES 





Voici donc les types principaux de surfaces que vous pourrez 
représenter. Ils sont tous suivis d’un exemple concret, donné par des 
chiffres qui sont les données que vous devez rentrer, dans l’ordre, dans le 
programme. La barre indique les moments où l’écran s’efface. 

Tout d’abord la sphère : 


x?+y?+72-R?=0 


(R est le rayon, une constante). Pas besoin d’épiloguer. 


Exemple : 
—4,0,0,0,1,1,1,0,0,0/1, 0,0,1,0/0.17/100,45,45 


qui vous donnera une demi-sphère. 
Variation sur la sphère, l’ellipsoïde est une sorte de ballon de rugby: 


D 


2 2 


CRAN ES LS 
Ah k 0 


(a,b,c,k, quatre constantes non nulles). 
Exemple : 
—4,0,0,0,1,1,2,0,0,0/1, 0,0,1,0/0.1/80/45,45 


L’hyperboloïde à une nappe rappelle les tours de refroidissement des 
centrales : 


RS US 
S+s-Ss-k=0 
& bb © 


(idem pour a,b,c,k). 
Exemple : 
—1,0,0,0,1,1,—1,0,0,0/2, 0,0,1,1, 0,0,1, —1/ 


0.05/100/60, 75 
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L’hyperboloïde à deux nappes est théoriquement en deux parties, mais 
vous ne pouvez en voir qu’une car le programme ne peut tracer deux 
morceaux disjoints. Il faudrait donc le faire repartir, par exemple, pour en 
voir plus (ce n’est pas passionnant, de toute façon) : 


x2 y z? 
stp ztk=0 


Exemple : 
+1,0,0,0,1,1,—1,0,0,0/1, 0,0,1,2/0.05/50/45,60 


Le paraboloïde ressemble au précédent, mais en plus rondouillard : 


2 


2 
ty 20 


a 


Exemple : 
0,0,0,1,1,1,0,0,0,0/1, 0,0,1,1/0.05/80/45,45 


Le cône, qui tient le milieu entre les deux hyperboloïdes, est une forme 
bien connue qui provient du conoïde : 
2 2 
x, y 2 
+2" =0 
& b 
dans le cas où a = b. Il est très difficile à représenter par ce programme, en 
grande partie à cause de son sommet qui est un point anguleux. Ce point 
sera donc généralement mal représenté, avec une sorte de brouillage (voir 
figure VII.C.). 


Exemple : 
0,0,0,0,1,1,—1,0,0,0/2, 0,0,1,1,0,0,1,—1/0.05/80/45,60 


Vous pouvez voir ces exemples sur les Figures VII.C, n°* 1 à 6. Il va sans 
dire que vous pouvez utiliser bien d’autres types d'équations. Mais vous 
retomberez presque toujours sur un de ces types ; simplement, la figure 
sera orientée différemment, ou plus grosse. Rien ne vous empêche de faire 
des essais au hasard, surtout si vous aimez les surprises. 

Si vous préférez passer à des choses plus simples (comme je vous 
comprends !), changez simplement de chapitre, en tournant la page. 
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VIII 
L'OMBRE 
ET LE FOND DES CHOSES : 
COUPONS, TRANCHONS, 
PLAQUONS 








Après avoir vu comment créer et tracer simplement certains objets, et avant de 
nous attaquer à une conception plus exacte de la vision, au Chapitre X, nous allons 
citer ici quelques petits trucs pas trop difficiles qui permettent de rendre vraiment 
plus réalistes les travaux de votre ordinateur et également de les analyser plus en 
profondeur. 

Si vous savez à présent comment tracer des objets complexes, vous ne savez 
peut-être pas encore comment en tracer l’ombre, par exemple, ou le reflet dans un 
miroir, une vitre, ou une étendue d’eau. Or, ce sont précisément ces détails qui 
rendent vraiment réalistes les dessins en trois dimensions. 

D'autre part, les objets un peu compliqués sont toujours plus faciles à 
comprendre si on les décortique. Votre ordinateur vous permet de le faire sans 
“casse” ; il serait dommage de ne pas en profiter. Ainsi, pour des utilisations 
presque professionnelles aussi bien que dans les jeux, les coupes et sections se 
révèlent parfois d’une étonnante utilité. C’est ce que nous verrons dans la seconde 
partie de ce chapitre. 


1. OMBRES ET REFLETS : LES MIRACLES+DE LA PROJECTION 





Nous sommes à présent bien familiers avec la projection car, en fait, 
c’est ce que nous ne cessons de faire depuis le début. Toutefois nous ne 
connaissons qu’un type de projection, la projection orthogonale. Rappe- 
lons que ce qualificatif provient de ce que le segment joignant un point et 
son projeté est toujours perpendiculaire au plan de projection, l’écran en 
l'occurrence. Pour nous, cette définition rébarbative se traduisait par une 
réalité bien simple: dans le repère lié à l’écran, où son équation est 
Z = constante, il suffisait de ne pas tenir compte de la troisième 
coordonnée ZZ ; il en résultait qu'il suffisait de calculer XX et YY, ce qui 
était bien commode. 


FROGRAMME _ WITII. 1 





534 e2159/SORCrmax ) 

559 WINDOW #1,21,49,1,25 

564 alPha=4S:f9a=1 

645 fam=g 

615 nBzslksd4+cd4tcike2:nlz-sdtci+cd4ts2#s1: n2=c2#kcé 

625 IF f9M=Q THEN Prod=ci#s2#n0t, @2+s1ks?#%nt, 12+c2#nct.2) ELSE 
Prod=n@kntt,92+n1%nct, 12+n?2#ntt,2) 

739 IF faM=1 GOTO 2448 

749 IF f9a=i GOT) 445@ 

759 f9m=1 

768 GOTO 628 

1199 PLOT -164,0,3 

112@ DRAW 156%x31-169,-159#c1#xc2: PRINT"*«"; 

1139 PLOT -169,6 

1148 DRAW m0 169,-158%s1%xc2: PRINT"y"; 

1159 PLOT -168 

1169 DRAW -168, Tsoxs2: PRINT"z"; 

1213 XX=XX-168 

123@ IF f9M=9 THEN RETURN 

1249 ZZ=(s2%c14kx+=2%ks1%y+c2Xz ke 

1259 XX=-CXX+16824kc4+27*%2:4+169 

1264 RETURN 

2474 a=INKEY(S42:IF a<>-1 THEN GOSUB 1999:a1Pha=alPha-b:GOTO 4948 
2984 a=INKEY(46):IF a3<2-1 THEN GOSUB 1999:21Pha=2lPha+b:GOTO 4099 
2496 GOTO 2918 

2645 PRINT:PRINT"_ B ou N Pour faire tourner le miroir. 

2825 PRINT:PRINT"_ B ou N Pour faire tourner le miroir. 

40908 ’===222===2222=2==222222=-22=222=2s2=s222=2=====22s=22= Rotation du miroir 
4819 s3=SINCalPha):c3=C0SCalP ha) 

402@ =:4=SINC2#alPha ):c4=C0SC2#a1P ha ) 

4038 CLS #1 

4940 IF 33>8 AND c3>A THEN f92=0:f9M=1:GOTO 615 

4950 PEN 2:LOCATE 21,14 

4964 PRINT"'Miroir mal oriente" 

4976 PEN 1:GO0TO0 2498 





Cela ne le sera plus, et dans le Programme VIIL.1 il faudra calculer ZZ 
(ligne 1240). Avant d’expliquer pourquoi et ce que fait ce programme, je 
dois préciser qu’il est destiné à être amalgamé avec les Programmes VI.2 
(et ceux qui accompagnent) et VI.S, qui forment un tout permettant de 
tracer tous les polyèdres de répétition cylindrique, avec parties cachées. Il 
en sera de même des deux autres programmes de ce chapitre. J’ai choisi ce 
type de polyèdres car ils sont les plus simples, mais évidemment, rien ne 
vous empêche de réadapter les programmes de ce chapitre pour tous les 
objets que nous sommes parvenus à tracer. 





Figure VIIL.I (a) 
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Figure VILA (@) 


Le Programme VIIL.1 donne un exemple de ce que peut permettre la 
connaissance des projections obliques. Expliquons d’abord ce qu’elles 
représentent à l’aide de la Figure VIIL.A, schéma 4, à gauche. Soit, dans 
un repère donné, une droite D qui fait, dans le plan xOz, un angle 8 avec 
Ox. Pour tout point À de l’espace, on appelle projection de A sur Ox 
parallèlement à la droite D, le point a du plan yOx qui est tel que le 
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segment Aa est parallèle à D. Si D est perpendiculaire à yOx, nous 
retrouvons la projection orthogonale habituelle. Cela est confirmé par la 
matrice de cette projection, qui s’écrit : 


1 0 — cotg (8) 
0 1 0 
0 0 0 


Rappelons en effet que la cotangente est l'inverse de la tangente, et vaut 
0 pour un angle droit. Dans ce cas, on retrouve la matrice de projection 
déjà citée. À quoi servent ces projections obliques ? Il y a deux utilités 
principales. D’une part, si le soleil se trouve dans la direction pointée par la 
droite D, et si on a en À une petite bille par exemple, eh bien, en a se 
trouve l’ombre de la bille sur le sol (plan xOy). Ainsi, les projections 
obliques permettent de dessiner l'ombre d’un objet, même lorsque le soleil 
n’est pas au zénith. 

C’est une autre utilisation, plus particulière mais aussi plus fine, que 
nous allons développer à présent. Sur le schéma a, à droite, on a dessiné 
un objet quelconque, l’écran E vu de dessus, et un miroir M vu aussi de 
dessus, ce miroir étant vertical comme E, et sa normale inclinée d’un angle 
æ avec E. Le dispositif est représenté plus clairement sur le schéma b 
(toujours de la Figure VIII.A). Vous constatez ainsi que sur l'écran, on 
peut voir non seulement la projection normale de l’objet sur la moitié 
gauche, mais en outre, sur la moitié droite, la projection du reflet de 
l’objet dans le miroir. 





Figure VIIL.B : Un polyèdre.. et son reflet. 
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Si le miroir avait été choisi horizontal au lieu de vertical, on aurait pu 
avoir un effet d’objet se mirant dans une flaque d’eau. Si on noircissait tout 
le contenu du reflet, on verrait alors l'ombre portée par l’objet sur un mur, 
la lampe étant placée dans la direction de la droite D du schéma a, à 
droite. Comme ce sont des cas plus simples (qui peut le plus peut le moins), 
je vais vous expliquer comment obtenir effectivement sur votre écran à la 
fois l’image de l’objet et son reflet. 

Les lois de l’optique affirment que, lorsqu’un rayon lumineux est dévié 
par un miroir, comme le sont ceux du schéma a, ils font le même angle à 
avant de ne se réfléchir qu'après. Il suffit de le savoir. 

Notez au passage que i est égal à 90 — « (en degrés). Il en résulte que f 
(voir schéma) vaut 90 — 2j, soit 2 — 90. Toutes ces relations angulaires se 
déduisent de la figure. Au passage, je vous conseille donc de ne jamais 
omettre de faire une figure bien propre avant un raisonnement de 
géométrie, faute de quoi on ne s’en sort jamais. 

Avant de rentrer dans le détail des calculs, je dois parler un peu de 
l’angle «. Un miroir, chacun le sait, a un côté réfléchissant et l’autre mat. 
Sur le schéma c, ce dernier a été grisé. Le vecteur normal au miroir est 
celui qui sort par la partie réfléchissante. Ce schéma c représente les 
quatre positions types du miroir selon la valeur de « par rapport aux angles 
0,90°, — 90°, 180° et — 180° (à 360° près comme toujours pour des angles). 
On voit que c’est seulement lorsque « est compris entre 0 et 90° qu’il ya un 
reflet visible sur l'écran. Autrement, suivant les cas, soit il n’y a pas de 
reflet du tout, le miroir présentant sa partie mate, soit le reflet se trouve du 
côté opposé à l'écran et est donc invisible (en haut à droite). Dans la suite, 
nous supposerons donc «& compris strictement dans l'intervalle [0,90°]. 

A présent, penchons-nous sur le complexe schéma d. Soit A un point 
quelconque, de coordonnées XX, YY, ZZ dans le repère O’, X, Y,Z de 
l'écran. Ces coordonnées se déduisent de x, y, z, coordonnées du repère 
Oxyz, par les formules de rotation habituelles, auxquelles il faut toutefois 
ajouter l’opération XX = XX — 160 (ligne 1215 du Programme VIIL.1). En 
effet, comme nous voulons représenter à la fois le polyèdre et son reflet, 
mais pas superposés, il faut centrer le polyèdre sur la partie gauche de 
l'écran, et centrer le miroir sur la partie droite. Il existe une infinité de 
rayons issus de A qui viennent frapper l'écran E. Mais, de tous ces rayons 
lumineux, un seul nous intéresse, celui qui revient perpendiculaire à E. Ce 
rayon est dévié par le miroir en B. Il faut, au total, connaître la différence 
entre les abscisses b et a de B et A, pour pouvoir faire le tracé de B. Pour 
cela, il existe plusieurs méthodes. L’une d’entre elles consiste, après s’être 
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mis dans le système de coordonnées adapté au miroir X1, V1, Z1, qui se 
déduit de O’, XYZ par une simple rotation d’angle x/2 — «æ autour de 
O' Y (voir figure), à faire la projection oblique dont j'ai déjà parlé. 
Attention toutefois, car dans ce système de coordonnées le miroir a pour 
équation z, = L, où L est la distance de O’ à M, ou encore la distance KH. 
A propos de L, notez que, comme H est à la verticale de O’ (ce n’est pas un 
hasard de figure, et j'expliquerai tout à l'heure pourquoi), et comme OO" 
vaut 160 et qu’enfin l’angle O' OH est «, on a les relations suivantes : 





H = ” et OK=160cos(«) 
cos (æ) 
d’où 
Le. L __ 160 sin” (æ) 
L = KH = 160 Fe @) cos (a) Et) 


L est ainsi calculé. On peut donc trouver les coordonnées de B. 

Une fois n’est pas coutume, je voudrais exposer ici un calcul 
géométrique de la distance de b à a. Il y a là une arrière-pensée. Si, en 
effet, vous cherchez à refaire le même travail de miroir en perspective 
optique (voir Chapitre X), vous ne pourrez plus utiliser les projections 
obliques. Par contre, vous pourrez utiliser une loi de l’optique qui affirme 
que, lorsque vous regardez dans un miroir, vous semblez voir le symétrique 
de l’objet reflété par rapport au plan du miroir. Ainsi, placé devant l’écran, 
vous semblez voir en b le point A’, symétrique de A par rapport à M, et 
qu’on appelle de ce fait son image. Ce n’est donc pas réellement B qui doit 
être dessiné sur l’écran, mais A’. En fait, il se trouve qu'ici ces deux points 
se projettent tous les deux en b. Néanmoins, cette remarque permet de 
calculer b — a sans trop de problèmes. En effet, A’ étant le symétrique de 
À, le point P est à la fois le milieu de A’ et À, et la projection (orthogonale 
cette fois) de A sur M. Dès lors A’A = 2 AP. Or AP = 2, + L, où z, est la 
troisième coordonnée de A dans le système d’axes dont j'ai parlé tout à 
l'heure. Enfin, l’angle PAQ vaut a. Donc b — a = AQ vaut 2 (z, + L) cos (w). 
Nous avons calculé L tout à l’heure, et z, vaut ZZsin (æ) — XX cos (æ). 
Après transformation, et compte tenu des valeurs des sinus et cosinus de 
l’angle double obtenu en Chapitre Il, on obtient la formule de la 
ligne 1250 du programme. 

Notez que si A était en O, il faudrait que b vaille 160 pour que le miroir 
soit bien centré. C’est dans ce but que le miroir est déplacé vers l’arrière ou 
vers l’avant par rapport au polyèdre, selon la valeur de l’angle «. De ce 
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fait, le symétrique de O par rapport à M (non marqué sur la figure) est à la 
verticale de Q (homologue de B dans le cas A = O), et H est au milieu de 
l'écran, ce que j'avais affirmé tout à l’heure. 

Donc, lorsqu'on tourne le miroir (cela se fait avec les touches B et N 
dans le programme), celui-ci doit en outre reculer ou avancer, faute de 
quoi le reflet sortirait de l’écran. Mais il y a pire : il doit aussi changer de 
largeur, sinon le reflet sortirait.. du miroir, ce qui est un comble ! En fait, 
dans le programme, on suppose que le miroir est extrêmement grand, c’est 
pourquoi on n’en dessine pas les bords à l’écran. Ainsi, on peut sans souci 
tracer tout le reflet à l'écran. Cela, pourtant, n’est pas obligatoire. A votre 
avis, comment peut-on faire autrement ? (Question VIII. a.) 

Avant d’en finir avec ces histoires de reflets, quelques mots sur le 
Programme VIII.1. Dans ce programme, la pression des touches 
Q, W, O, P fait déplacer le polyèdre comme d’habitude, mais aussi son 
reflet, qui est tracé juste ensuite. Par contre, l’appui des touches B ou N 
fait tourner le miroir sans bouger le polyèdre. C’est pourquoi seule la 
fenêtre 1 (ligne 550) est vidée : c’est la partie droite de l’écran, et ainsi seul 
le reflet est retracé. 

D'autre part, le reflet, comme l’original, prend de la place. Ce dernier 
est plus petit qu'avec le programme des polyèdres seul. D’où une 
modification des lignes 530 et 1100 à 1160. Notez que deux flags sont 
utilisés dans ce programme : fgM indique à la machine si c’est au reflet ou à 
l'original d’être tracé; fga indique si l’angle est valable. Dans le cas 
contraire, vous verrez l'inscription Miroir mal orienté apparaître à la place 
du reflet. Appuyez alors sur B ou N, le reflet finira par se tracer. A propos 
de ces touches, sachez que vous pouvez également les utiliser avec SHIFT 
et CTRL, comme les touches Q, W, O, P. Cela permet des rotations plus 
ou moins rapides du miroir. 

Enfin, je répète qu'il est facile de réadapter ce programme, soit pour des 
tracés différents, soit pour des miroirs placés autrement (horizontaux par 
exemple). Rien ne vous empêche donc à présent de mirer n'importe quoi... 
des alouettes, par exemple ! 


2. PRINCIPE D’UNE SECTION. APPLICATION AUX POLYEDRES 





De même que Monsieur Jourdain faisait de la prose sans le savoir, votre 
charcutier ignore probablement qu’en vous coupant une tranche de 
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jambon, il vous fait une section de ce morceau de porc. On appelle en effet 
section une sorte de tranche d’un objet, ou plus exactement l'intersection 
d’un objet avec un plan donné. 

Faire une ou plusieurs sections d’un objet un peu compliqué peut 
permettre d’en accroître notablement la compréhension. Cela montre en 
effet l’intérieur de l’objet. Ainsi le scanner est-il un appareil qui permet 
d’obtenir des sections des différentes parties du corps... sans avoir à le 
découper réellement, heureusement. 

Faire une section d’un objet n’est pas une opération très difficile en 
général. Toutefois, cela peut être assez long. En effet, si l’objet est une 
surface (ou une réunion de surfaces par extension), d’équation 
f(x, y,z) = 0, et si le plan de section a pour équation z=a:x+b:y+c, 
par exemple, en remplaçant z par sa valeur on obtient une équation 
implicite qui ne pourra, en général, être résolue que point par point, ce qui 
risque d’être un peu long (voir l'Annexe B à ce sujet). 

Toutefois, dans certains cas, cela peut être très facile. C’est le cas 
notamment si la surface interceptée est un morceau de plan: l’intersection 
est alors un segment qui peut être tracé instantanément si l’on en connaît 
les extrémités. 

C’est la raison pour laquelle nous allons étudier la section sur l’exemple 
des polyèdres, dont les faces sont effectivement des morceaux de plans. 


FROGRAMME WITI-Z 








ñ 
n 






















2455 IF INKEYC6A3<>-1 GOTO 49%4 

2645 PRINT:PRIHT"_ S pour ohtenir une section" 

2825 PRINT:PRINT"_ S$ Pour ob ir tion" 

AADA ‘=zzzzs2szss2ees === SECTIONS PARALLELES À L'ECRAN 
4414 LOCATE 1,1:INHPUT 

4424 GOSUE 1944 

48324 FOR t=G TO f-1 

4444 <4=û 

445G FOR u=A TA AACt I 1 

nc szclksrkact nu, Ai+elke?kact,u,1)+c2%act,u,?)-cste 
4474 IF <=4 THEH GASUR 4F49:GOTO 4234 

4484 IF A<a GOT 4264 

4 





Premier Point de section 





sa 
Bio To À 
u+1 TO AHCtO-1 
BHact,s,A+z1#s2#act y, 1)+c2#att.vy,23-cste 
THEH =: GOSUE 476 OT 442% 

IF sxs@<4 THEN uuzv-liuzv:GOTO 4494 

sû=s 


308 NEXT 
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4314 u=HACE 1 :uu=g 
446g * 
4414 GOSUR 45 

4424 DRAM XX, 
GOTO 4114 



















4SGA ‘=== ‘alcul du Point de section 
4514 qui Ctiu, Lo-att uns 1234 
ce#k(act,u,23)-aft,uu, 22 

4524 IF AESCquotient <A,.4ñ1 THEH k=A FLSF k=s/aquotient 

4524 x=act u,@i-k#C actu, A)-act un. A5) 

4544 : #éaétiu 12-act;un, 132 

4554 Ct,u,2i-k#tact,u,23-ait,;uu, 20 

4564 GOSUE 1248 

4574 ! 

4746 Cas particuolier:eommet sur le Plan de section 
4714 » 

4724 

4734 

474 

4734 

















Le Programme VIIL2 est, comme le précédent et le suivant, destiné à 
être rajouté au programme de création de polyèdres à répétition 
cylindrique. Cela fait, l’appui de la touche S permet de passer au calcul 
d’une section et à son tracé. 

Plutôt que rentrer quatre constantes, il suffit ici d’en rentrer une seule, la 
section se faisant alors automatiquement parallèlement à l’écran, par le 
plan d’équation ZZ = cste. L’entrée de la constante permet de faire des 
sections successives. Pour faire des sections en des endroits variés du 
polyèdre, il suffit de le tourner suivant la bonne direction, par la méthode 
habituelle. 

Comment la machine réalise-t-elle le tracé de cette section ? C’est assez 
simple. Tout d’abord, je rappelle que si l’on a un point de coordonnées 
(a,b,c) par exemple, et un plan d’équation ux + vy + wz + k= 0, il suffit 
de calculer s = ua + vb + wc+k pour savoir si le point est en avant (s 
positif par exemple), en arrière (s négatif) ou sur le plan (s = 0 dans ce 
dernier cas). 

Dès lors, prenons une face du polyèdre. Connaissant l’équation du plan 
de section (ici u, v, w sont les coordonnées de la normale à l’écran, et 
k = — cste), nous pouvons calculer s pour tous les points de la face. Si, pour 
chaque point de la face, s est du même signe que pour le point précédent 
(so dans le programme), ce qui se traduit par s : 5, positif, alors la face est 
tout entière d’un même côté du plan; elle n’est pas coupée. 

Si, par contre, on finit par avoir s : 5 négatif, c’est que s a changé de 
signe, donc que le dernier point de calcul, appelons-le A, est du côté 
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opposé au plan de section du point précédent B. Dès lors, le segment AB 
est coupé par le plan de section. Il faut trouver le point d’intersection. 
Comment faire ? C’est très simple. Ce point étant sur la droite AB, il existe 
nécessairement un nombre k tel que x = ao — k : (ao — bo), etc., &o, etc. 
désignant les coordonnées de À, bo, etc. désignant celles de B, et x, y, z 
celles du point recherché. Pour trouver k, il suffit de se rappeler que le 
point est également sur le plan de section. Cela nous donne une équation, 
et l’on peut ainsi trouver k par un simple quotient, ce qui se fait aux 
lignes 4500 et suivantes dans le programme. 

Ce premier point de section trouvé, il faut en chercher un autre car j'ai 
dit que la section d’une face par un plan est (en général) un segment : il en 
faut donc la seconde extrémité. Pour cela, il suffit de repartir du point A et 
de continuer notre test. Lorsqu’enfin on a trouvé un second produit 
s * 5) négatif, il suffit de répéter les mêmes opérations pour trouver le 
second point d’intersection, puis de tracer une ligne entre les deux avant de 
passer à la face suivante. Si aucun point ne donne un produit s : 50 négatif, 
arrivé au dernier, le programme suppose que le plan de section passe entre 
le dernier point de la face et le premier, et continue. Ce faisant, il omet un 
cas particulier qui est alors mal traité. Lequel et, à votre avis, comment 
peut-on corriger ce défaut ? (Question VIIL.b.) 

Précisons que le programme traite les cas particuliers où l’un des 
sommets de la face se trouve dans le plan de section, ainsi que celui ou 
l'intersection est l’une des arêtes de la face. Ce dernier détail n’est pas 
évident mais c’est la vérité, réfléchissez bien. 

Il ne vous reste plus qu’à tester ce petit programme avant de passer à 
plus exaltant, les coupes. 


3._ PRINCIPE D’UNE COUPE. APPLICATION AUX POLYEDRES 


Les sections sont faciles à faire, mais elles ont l'inconvénient d’un léger 
manque de clarté; il est parfois difficile d’y reconnaître les formes de 
l’objet d’origine. 

Ce n’est pas le cas des coupes, dont l’usage, dans l’ensemble des 
techniques, est beaucoup plus répandu. En contrepartie, elles sont un peu 
plus difficiles à réaliser. 
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Pour expliquer de quoi il s’agit, je vais me permettre de faire une 
nouvelle fois référence à votre charcutier (si vous en avez un). Lorsque 
celui-ci découpe une tranche de jambon, vous avez, avec la tranche, une 
section du jambon. Avec ce qu’il en reste, vous en avez une coupe. Une 
coupe est donc un morceau tout entier d’un objet que l’on suppose coupé 
en deux par un plan, alors que la section n’en est qu’une infime tranche. 

La coupe permet non seulement de voir l'intersection de l’objet avec le 
plan de coupe, comme la section, mais en outre ce qui reste de l’objet, 
derrière le plan, comme si vous aviez effectivement coupé l’objet, d’où son 
nom. De ce fait, il est plus facile, lorsque la coupe a été réalisée, de se 
représenter l’objet original tout entier, et de mieux situer le plan de coupe 
par rapport à celui-ci. Les renseignements apportés sont ainsi plus 
accessibles. 

Lorsqu'un architecte présente le plan d’une maison, il en présente en fait 
une coupe, le plan de coupe étant parallèle au plancher. Le plafond enlevé, 
on peut voir l’agencement des murs, voire des meubles, etc. 

La coupe est donc l’instrument d'investigation le meilleur, et peut aussi 
bien être utilisée dans des usages très sérieux et professionnels que dans de 
simples jeux, pourvu qu'il s’y trouve un décor un peu compliqué. 





Figure VIII.C: Coupes successives d’un polyèdre. Constantes 3-1.5-0. 


Les coupes ne sont pas très difficiles à réaliser sur ordinateur et je 
souhaite vous en convaincre sur le même exemple que pour les sections ; le 
Programme VIII.3 est donc également destiné à être rajouté au pro- 
gramme de polyèdres déjà cité. 
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FROGRAMME WITIT.3 





627 IF f9C<>9 GOTO 584 

734 ON faC+1 GOTO 2944,543a 

2474 IF INKEYC622<>-1 GOTO 5949 

2484 GOTO 2414 

2655 PRINT:PRINT"_ C Pour obtenir une coupe," 
2835 PRINT:PRINT"_ C Pour obtenir une coupe." 
3315 DIM c(smax):DIM fscf-1,2,1) 

SAAQ ’==mssnze2====2--22====-=2==se=ses COJPES PARALLELES À L'ECRAN 
5414 LOCATE 1,1:INPUT "Constante ";cste 

5924 faC=1:AAs=4:GNTO 64 

5434 fac=a 

5444 FOR u=@ TO AAs-1 

5459 x=fs0u,8,@):y=feiu,1,8):7z=fecu,2,4) 
5469 GOSUB 1299:PLOT XX, YY,1 

5979 x=fs(u,9,1):y=fa(u,1,1):7=facu,2,1) 
5084 GOSUB 1284:DRAU XX, TY 


5499 NEXT 
5194 GOTO 2444 
5590 ’sz=2==22=2=====2=222===22==2=-s222===2==2 Routine PrinciPale de coupe 


5314 vmax=AACt)-1:fa=4 

5520 FOR u=4 TO umax 

99334 c(ud=cixs2#act u,9)+21%s2#%act,u,1)+c2#act,u,2)-cste 
5549 IF c(u)kc(@<g THEN fa=i 

5550 IF c(u<@g THEN uäau:tä=t 

5368 NEXT 

5579 IF c(D}<=9 AND fa=à GOTO 634 

5394 IF f9=4 GOTO 724 

5594 FOR uv=1 TO umax 

3694 IF c(udkc(a<A GOITO 56274 

5614 HEXT 

5624 umineu:uusg 

5634 FOR v=umin+i TO umax 

3649 IF cuïkc(umin)<@ THEN ouszu:GOTO 5668 

5659 NEXT 

5669 IF uu=@ THEN vuuzumax ELSE uuuzi-1 

Sér@ IF c(umin)<=g THEN ui=umin:u2=uuu :u3=uu ud=umin-1 ELSE ui=uu:uZ=umin-1 
:U3=UmiN: V4=uuu 

5684 IF u2<u1 THEH w2=u2+imax+1 ELSE 2=u2 

5694 IF Prod<=@ GOTO 5764 

5704 FOR vzul TO v2 

3719 IF v>umax THEN u=v-umax-1 ELSE u=v 

5724 x=att,u,Adiuzatt,u,13:z=act,u.2) 

5734 GOSUB 1244 

544 IF v=zui THEN PLOT KK,YY,1:a=XX:b=YY FLSF DRAH XX, VY 
5734 NEXT 

5769 uvy=u2:uizu3:1=8 

5774 GOSUB 6694:IF Prod>9 THEN DRAU XX,YY 

5784 uvaul:uizud:l=1 

3794 GOSUB 64@0@:IF Prod>4 THEN DRAU XX, %%:DRAU 3,b 

5664 AAs=AAs+1 

5819 GOTO 724 

ÉAQQ ’=sszzszzzzz2zzsss=szz2z==z=2ss=ssesssss=zezz Caloul du Point de coupe 
65914 quotient=ciks?*#(act uv, Di-act,ui,@12+s1#e2%C actus, 1 -actoui, 1224 
c2kCact,uv,23-actiui,20) 

6424 IF quotient=A THEN k=4 ELSE k=cuv)/quotient 

6434 «sac tuv, D) k#Cactiuv.@-act ui, 

5444 touv,1)-kKkéactouw, 13-actoui, 10) 

6454 z=att,uv,2)-kKk(actouv,23-act,ui,;22) 

6466 fsCAAs,9,1)=x:fsCAAs,1,10=u:feCAAs,2,12=z 

647@ IF Prod>ä THEN GOSUB .128A 

6484 RETURH 
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Suivant le même principe que pour les sections, une coupe sera obtenue 
en appuyant sur la touche C. Le plan de coupe est également parallèle à 
l'écran, et l’équation est la même : ZZ = cste, la constante étant demandée 
au début, après l’appui de la touche C. 

Ici encore, on procède face après face. Les valeurs que nous avions 
appelées s sont conservées au cours du traitement d’une face donnée dans 
une petite matrice c. Quant aux points de la section, qui forment une sorte 
de face supplémentaire au polyèdre coupé, ils sont conservés dans la 
matrice fs, pour des raisons que j’expliquerai tout à l’heure. Ces deux 
matrices sont dimensionnées juste après a (ligne 3315). 

Lorsqu'on pratique une coupe, plusieurs cas peuvent se présenter 
suivant les faces. 


1. La face n’est pas coupée : tous les c(4) sont du même signe que c (0) 
(qui sert ici — arbitrairement — de référence). Dès lors, fg est mis à 
zéro. Si c(0) est de surcroît négatif, la face est tout entière visible (car 
on trace ce qui se trouve en arrière du plan de coupe) ; il ne reste qu’à la 
tracer normalement. Sinon, la face est en avant du plan de coupe : on ne 
trace rien et on passe à la suivante. Tout cela se traduit par les 
lignes 5500 à 5580. 


2. La face est coupée, le flag fg est à 1. Cela se produit lorsque l’un des 
c(u) a un signe opposé à c (0). Cette valeur de u est appelée un temps 
Umin. Comme pour les sections, on cherche alors une seconde valeur de 
u telle que c (u) soit du signe opposé à € (umin). Cette valeur est appelée 
uu. Si on ne la trouve pas, c’est que tous les points de Uin à Umax 
(dernier numéro) sont du même côté, donc que le premier à être du 
côté opposé est le point numéroté 0. Dans ce dernier cas, son 
prédécesseur est UUU = Urmnax: SINON UUU = uu — 1. 


On a à présent les segments coupés : ce sont ceux qui joignent les points 
de n°Ÿ Umin — 1 et Unin, d’une part, uuu et uu, d’autre part. Reste, suivant 
le signe de C(umin), à savoir, dans chacune de ces deux paires, lequel est le 
visible, et lequel le non visible (qui est en avant du plan de coupe). Cela est 
fait en ligne 5670. Dès ce moment, uw, u:, u3 et u4 désignent 
respectivement les numéros d’ordre du premier point visible, du dernier, 
du premier point non visible et du dernier. 

On est alors presque au bout. Que faut-il faire à présent ? 

Tout d’abord, tracer les segments visibles de la face, à condition que 
prod soit positif (car la face peut être visible du point de vue de la coupe, 
mais néanmoins cachée par les autres faces). Puis chercher, sur chacune 
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des deux arêtes coupées (u1,u4) et (u>,u3), le point d’intersection avec le 
plan de coupe, ce qui est fait de la même manière que pour les sections, par 
la routine des lignes 6000 et suivantes. Pour cette routine, je signale que uv 
désigne le numéro du point visible du segment coupé, et ui celui de 
l'invisible. Cela a de l’importance. Si prod est positif, encore une fois, on 
trace les petits morceaux visibles des segments coupés. Sinon, rien n’est 
tracé. 

C’est seulement une fois la dernière face traitée que le programme 
s'oriente sur la ligne 5030 (en 730). Là, on parachève le travail en traçant la 
section dont les points ont été conservés dans la matrice fs. Puis l’on 
revient au clavier. 

L’utilité de cette conservation des points de la section sous la forme 
d’une matrice n’est pas évidente. En fait, elle vise de légères extensions de 
ce programme que vous n'aurez, je pense, guère de mal à faire 
vous-même. La première permettrait de retracer ensuite la section seule. 
La seconde permettrait de faire pivoter le polyèdre ainsi coupé, sans le 
reconstituer tout de suite. Il suffirait pour cela de conserver également 
pour chaque face les valeurs de u, et u,, s’il y a lieu. 

Précisons enfin, au sujet de ce petit programme très extensible, qu’en 
outre il peut être rajouté aussi au programme de section (VIIL.2). Vous 
disposeriez ainsi d’un programme permettant les deux opérations à la fois 
(les numéros de lignes ont été spécialement prévus à cet effet). Enfin, il ne 
tient qu’à vous de l’adapter, comme le précédent, à d’autres objets que les 
polyèdres. Cela sera certainement moins difficile que la création même de 
ces autres objets. 
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REPONSES AUX QUESTIONS DE CE CHAPITRE 


Question VIIL.a 


On peut tracer les bords du miroir (ils ont pour abscisses 
160 — K : sin («œ) et 160 + K : sin («), où 2K est la largeur du miroir). Dès 
lors, si le reflet déborde (abscisse d’un point non comprise entre ces deux 
bornes), il faut calculer l’intersection du segment théorique avec le bord du 
miroir, et ne tracer que jusqu’à ce point. L’image n’est pas alors entière. 


Questions VIIL.b 


On omet le cas où un seul point est commun à la face et au plan de 
section. C’est alors obligatoirement un sommet. Pour corriger ce défaut, il 
suffit de calculer s au point u =0 en ligne 4310. Dès lors, si s : s) est 
négatif, faire comme en ligne 4310 et aller en 4400, sinon passer 
directement à la face suivante sans rien tracer de plus. 
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1x 
LA NAPPE A CARREAUX : TRACE 
D'UNE SURFACE QUELCONQUE 
EN TROIS DIMENSIONS 





Nous avons vu au Chapitre VII comment tracer un morceau de surface 
polynomiale. Nous allons à présent chercher à tracer une surface absolument 
quelconque, mais pas de la même façon. Ici, il s’agira de tracer un quadrillage porté 
par la surface et qui la fera ainsi apparaître, et non d’en tracer l’horizon, chose que 
nous savons d’ores et déjà faire en théorie, et rarement exécuter en pratique (car le 
calcul de dérivées partielles quelconques est extrêmement difficile, voire 
impossible sur ordinateur). 

L'intérêt de ces surfaces quelconques n’est pas seulement “l’amour de l’art”. 
Sous la forme z = f(x, y), elles permettent de fabriquer très facilement des paysages 
splendides, qui peuvent fournir d'innombrables décors à des jeux extrêmement 
variés. C’est pourquoi l’étude de ces surfaces (à peine plus particulières que les 
autres en vérité), et notamment de leurs parties cachées, fera l’objet des trois 
derniers paragraphes de ce chapitre. 


1._ DEFINITION — PRINCIPES 


J'ignore si vous avez chez vous une grande nappe avec des carreaux, 
mais dans le cas contraire rien ne vous empêche de l’imaginer. 

Si vous posez une telle nappe sur une surface quelconque (votre table, 
par exemple), elle en épousera les formes, et les carreaux, en principe bien 
droits, se déformeront également. De ce fait, lorsqu'on verra ce spectacle 
de loin, les lignes de la nappe épousant les plis et replis de la surface 
permettront de se faire une idée très précise de cette surface que, par 
contre, on ne verrait pas très bien si elle se trouvait blanche et nue ; dans ce 
cas, seuls les jeux d’ombre et de lumière permettraient de voir les bosses et 
les creux. Or ces jeux n’existent pas sur votre ordinateur, où ils sont fort 
difficiles à mettre en œuvre (voir chapitre précédent). 

Par contre, il n’est pas très difficile de faire tracer sur une surface des 
lignes semblables à celles d’une nappe à carreaux, et l’effet tridimensionnel 
obtenu est souvent saisissant ; les figures de ce chapitre sont là pour en 
témoigner. 


Comment faire ? Ce n’est pas très compliqué pourvu que l’on s’entende 
sur les définitions. Car, en fait, qu'est-ce qu’une surface ? Nous avons 
jusqu'ici considéré la notion comme intuitive (elle l’est), mais nous allons 
néanmoins préciser un peu cette intuition. 

Dorénavant, le terme de surface désignera pour nous l’ensemble des 
points dont les coordonnées (x, y, z) (ou les coordonnées cylindriques, ou 
sphériques) obéissent à une équation du type f(x, y,z) = 0. La fonction f 
peut être à peu près n'importe quoi, pour nous qui ne souhaitons pas nous 
encombrer de subtilités mathématiques. De toute façon, cette fonction 
devra s'exprimer avec les fonctions mathématiques de votre Amstrad. Par 
exemple, l'équation 2x?+y?—cos(z)—1=0 représente une certaine 
surface, non polynomiale à cause du cosinus. 

Cette nappe pourrait être représentée directement avec le système des 
équations implicites, mais vous y seriez encore dans un mois ! Il y a en fait 
plus simple, car cette surface est aussi une nappe paramétrée. 

Ce nom de nappe paramétrée, qui n’est pas de moi, mais fait très 
sérieusement partie des mathématiques, désigne une surface ayant la 
particularité d’être paramétrable, c’est-à-dire telle qu'il existe deux 
paramètres u et v, et trois fonctions À, B, C de ces deux paramètres, afin 
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que x=Au,v); y=B(u,v); z=Clu,v) soit équivalent, pour toutes 
valeurs de u et de v, à f(x, y,z) = 0. 

Nous connaissons déjà cette histoire de paramètre pour les courbes du 
plan. Ainsi, souvenez-vous que le cercle qui a pour équation 
x? + y? — 1=0 peut être tracé sur votre ordinateur en écrivant x = cos (f), 
y = sin (f), et en faisant varier t de 0 à 360°. Dans ce cas, il n’y a qu’un seul 
paramètre, f, parce qu’il s’agit d’une courbe ; pour une surface, il en faut 
deux, et il y a trois coordonnées. Ne vous interrogez pas sur la signification 
de ces paramètres : ils n’en ont généralement aucune. Ce sont de simples 
intermédiaires de calcul, contrairement aux coordonnées qui, elles, 
représentent effectivement la position d’un point de la surface. 

Dans l’exemple donné, on s’aperçoit que si l’on pose x = cos (u) : cos (v) 
et y= V2: cos(u) : sin(v), on trouve 2x? + y? = 2cos?(u). Étant donné 
l'équation, on en déduit que cos(z) = 2 cos? (u) —1=cos(2u). On peut 
donc poser z=2u. On a alors les trois fonctions A, B,C. Cette 
démonstration semble tirée d’un chapeau de magicien, et de fait elle l’est. 
En effet, le problème du passage de l'équation dite intrinsèque 
f(x,y,z)=0 aux équations dites paramétriques x = Au,v), etc. est 
théoriquement toujours possible, mais en pratique fréquemment infai- 
sable, et de même du passage réciproque. L’exemple ici était spécialement 
conçu. 

Nous supposerons à l’avenir que l’on a su trouver les équations 
paramétriques sur la surface, ou plutôt que l’on s’est donné la surface avec 
des équations paramétriques, car l’équation intrinsèque, malheureu- 
sement, n’est pas d’un bien grand usage (voir néanmoins les Annexes A 
et B). 

Partant des équations paramétriques, par contre, tout est simple. 
Rappelons tout d’abord qu’on ne peut tracer la surface en soi: on 
n'obtiendrait guère sur l’écran qu’une grosse tache, voire un écran 
entièrement lumineux, ce qui ne renseigne guère. 

Nous allons tracer des courbes qui sont sur la surface, comme si avec un 
crayon on s’amusait à dessiner dessus. Les ondulations des ces courbes 
mettront en valeur le relief de la surface. 

Quelles courbes tracer? Les plus simples possible. Remarquez tout 
d’abord que, dans l’espace, une courbe peut aussi avoir des équations 
paramétriques, comme dans le plan, du type x=a(f); y=b(f); z=c(t), 
où a,b,c sont des fonctions du paramètre f (rappelez-vous: un seul 
paramètre pour une courbe, deux pour une surface). Dès lors, remarquons 
que si l’on impose par exemple à w d’avoir une valeur fixe wo, on peut 
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appeler a, b, c les fonctions de v définies par: a(v) = A (wo, v), etc. Par 
exemple, si # = 0, et avec les fonctions que nous avions précédemment : 


x = cos(u) : cos(v) devient x= cos (0) - cos(v) = cos (v) 
y= VZcos(u) : sin(v) devient y= V2sin(v) 
z=2u devient z=0 


x, y, z ne sont plus les fonctions que d’un seul paramètre, l’autre étant 
maintenu constant. Le point se trouve donc sur une certaine courbe (ici, 
c’est une ellipse se trouvant dans le plan z = 0). Pour tracer cette courbe, il 
suffit de faire varier v de vi à va (par exemple de 0 à 360°). Pour 
chaque point, on calcule x, y, z, puis XX et YY (n'oublions pas la 
projection), et on place un petit point sur l’écran avant de passer à la valeur 
suivante de v. C’est à peu près aussi simple que pour une courbe plane. 
Lorsque la courbe est finie, c’est w, que l’on change, et on recommence, 
Uo, c’est-à-dire u, variant entre chaque courbe de Uin à Umax. Lorsque 
toutes ces opérations sont finies, on obtient une succession de courbes les 
unes à côté des autres. Pour avoir un quadrillage, il faut des courbes dans 
l’autre sens: il faut alors faire un tracé à v constant. 
Voici le programme que cela donnerait : 


FOR u = umin TO umax STEP (umax-umin)/n : 

FOR v = vmin TO vmax STEP h: 

X = cos (u) * cos (v):y = cos(u)*sin(v)*sqr(2):z=2*+u: 
GOSUB “calcul de xx et yy” : DRAW XX, YY : next: next 


puis recommencer en échangeant le rôle de u et v. 

Dans ce programme, comme dans tout autre similaire, h désigne la 
finesse du tracé (plus h est petit, mieux les courbes sont faites, mais plus 
c’est long), et n le nombre de courbes sur les côtés du quadrillage (nombre 
entier ; plus n est grand, plus le quadrillage est petit et esthétique, mais 
plus le tracé est long). 

Je vous propose d’essayer ce petit programme, avec des fonctions 
variées. Le calcul de XX et YY est toujours le même. Prenez garde en 
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choisissant vos fonctions, ainsi que ui, etc., que la surface ne déborde pas 
trop de l'écran: vous risqueriez de ne plus rien voir, et en plus d’avoir un 
message d’erreur. 


2. USAGE DES COORDONNEES NON CARTESIENNES 
— USAGE DES FONCTIONS MATHEMATIQUES 








Nous avons jusqu’à présent parlé des coordonnées cartésiennes x, y, z, 
mais rien n'empêche d’en utiliser d’autres. Nous connaissons ainsi les 
coordonnées cylindriques (r,@,z) et sphériques (r, ÿ, 6). Si l’on écrit dans 
ces systèmes de coordonnées des équations paramétriques r = A (u,v), 
etc., nous obtiendrons aussi une nappe paramétrée, différente bien sûr. 
Cela ouvre un champ,nouveau de dessins de surfaces. 

Le calcul des coordonnées projetées XX, YY n’est guère plus 
compliqué. Avec: 


XX=(s:x-c y)'e et YY=(5 :z—-c:(c' x+s y) 'e, 
on obtient les formules suivantes : 
En cylindriques : 

XX =e:r:sin(psi-) 

YY =e:(s:z—c:r:cos(psi—œ)) 
En sphériques : 

XX =e-r:sin(psi-Y) : sin(6) 

YY =e-r:(s,: cos(8)—c; : sin (8) : cos (psi — y)) 
Attention ne pas confondre dans ce dernier cas (ÿ,6), coordonnées 
angulaires cylindriques du point projeté, et (psi, thêta), coordonnées 
angulaires de la direction d’observation. 

Le programme (ou plutôt l’esquisse de programme) donné ci-dessus 


peut sans difficulté aucune être adapté à d’autres systèmes de coor- 
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données. Ces autres systèmes peuvent permettre d’amples variations, mais 
je n’y insisterai pas, pour des raisons que je donnerai au prochain 
paragraphe. 

Avant de poursuivre, je dois vous mettre en garde contre les fonctions 
mathématiques utilisées trop vite sans précaution. Certaines fonctions 
méritent des gants parce qu’elles sont susceptibles de devenir infinies en 
certaines valeurs, ou assez grandes pour créer un overflow. Il s’agit 
notamment du logarithme (décimal ou naturel), infini en 0, de la tangente 
(infinie aux angles droits), plus généralement de toute division si le 
dénominateur peut s’annuler, mais aussi de l’exponentielle qui croît très 
fortement ; ainsi l’exponentielle d’un nombre supérieur à 88 créera un 
overflow. 

Ne soyez donc pas surpris si un message d’erreur apparaît, si vous n’avez 
pas vérifié que votre fonction ne créera pas de débordement. Dans ce but, 
étudiez avec soin le domaine de variation des paramètres, c’est-à-dire les 
valeurs données à min, Umax ©t Vmins Vmax- TTOP petites, vous ne verrez rien 
d’intéressant. Trop grandes, overflow. 


D'autre part, n'oubliez pas que les fonctions trigonométriques sont 
périodiques. Lorsque dans vos fonctions un paramètre n'apparaît que sous 
la forme de son cosinus, son sinus et sa tangente, inutile de le faire varier 
sur plus de 360° : vous feriez retracer plusieurs fois la même chose. C'était 
le cas par exemple de v, dans l'exemple donné au paragraphe précédent. 


Enfin, défiez-vous de l’arc tangente (atn) et de la valeur absolue (abs) 
ou, pire, de la fonction signe (sgn). Ces fonctions sont susceptibles 
d’engendrer des variations brutales dans certains cas, qui créeront des 
“marches d’escalier” dans votre surface, ou même des erreurs. A utiliser 
avec soin, surtout la fonction signe. 


Dernier mot sur le mode trigonométrique choisi : utilisez les radians. Je 
sais que jusqu’à présent nous avons utilisé les degrés, mais il faut cesser de 
le faire quand on a des mélanges de fonctions trigonométriques et d’autres 
fonctions. Par exemple, si vous avez x =cos(u) et y=exp(u), x est 
périodique en u. Si vous vous placez en degrés, et que vous voulez tracer 
une période entière (vous ne pouvez de toute façon tracer la courbe en 
entier, elle est infinie), de 0 à 360°, vous aurez un overflow dès que u 
vaudra plus de 89. Par contre, en radians, rien de grave : de 0 à 2pi, rien ne 
se passe car 2 pi = 6,28., donc pas d’overflow, tant s’en faut. Vous voyez 
sur un exemple bien innocent que les degrés peuvent provoquer des 
ennuis. Ces recommandations valent pour les paragraphes qui suivent. 


— 187 - 


3. CAS ESSENTIEL : z = f(x, y) 





Nous admettrons qu’il n’existe aucune méthode, et surtout pas de 
simple, pour tracer une nappe quelconque sans parties cachées sur votre 
ordinateur. 

C’est cependant possible en théorie. Il faudrait pour cela enregistrer 
pour chaque point de l’écran les différentes intersections avec la nappe. 
Cela exigerait probablement de dimensionner une matrice de 640 sur 200, 
ce qui est impossible pour cause de mémoire, mais surtout le tracé serait si 
lent qu’il rendrait fou d’impatience même un vieux pachyderme scléro- 
tique ! 

Par contre, une certaine sorte de nappe combine deux avantages 
essentiels. Premièrement on peut en gérer les parties cachées sans prendre 
le risque de devoir se faire enfermer. Deuxièmement, c’est elle qui a le plus 
d'utilité pratique. Il s’agit des nappes où x et y eux-mêmes peuvent servir 
de paramètres, du type x=x; y=y; z=C(x,y), ou encore d’équation 
intrinsèque C(x,y)—z=0. C est une fonction quelconque de deux 
variables, que nous appellerons f dans la suite, puisque c’est la seule 
fonction en présence. 


Pourquoi cette nappe a-t-elle une plus grande utilité pratique que les 
autres? Cela dépend évidemment de ce que l’on souhaite faire de ces 
nappes paramétrées. En dehors de leur intérêt esthétique, elles forment un 
très beau paysage pour un jeu informatique (vous en avez probablement 
déjà vu, sinon les figures de ce chapitre le démontrent, me semble-t-il), soit 
telles quelles, soit avec de petites modifications. L’une de ces modifications 
possibles consiste, au lieu de tracer les carreaux, à ne pas tracer du tout de 
courbes, mais à mettre, aux points d’intersection de ces courbes virtuelles, 
de petits caractères. Ainsi, une surface ressemblant à une montagne pourra 
être retracée, en mettant là où les lignes se croisaient de petits caractères 
en forme de sapins. On aura alors l’impression de voir une montagne 
couverte d’une forêt de sapins. Naturellement, les variations sur ce thème 
sont infinies. Pour l’application de cette idée, elle est si simple, à partir du 
Programme IX.1, que je n’ai pas jugé utile d’en donner le détail. Je l’ai 
personnellement fait en modifiant moins de dix lignes dans le 
Programme IX.1, alors. 

Tout cela cependant ne répond pas encore à la question de savoir 
pourquoi elles font de meilleurs paysages que d’autres, ces nappes. C’est 
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assez simple. L’axe Oz représente la verticale. L’équation z =f(x, y) 
signifie que pour une valeur donnée du couple (x,y), c’est-à-dire à la 
verticale d’un point donné du sol (plan xOy), il n’y a qu’un seul point de la 
surface. Or c’est le cas en général dans la nature : le sol, sauf gros accidents 
de terrain, n’a pas de replis verticaux. En un point donné d’une carte, il n’y 
a qu’une altitude possible : cette altitude, c’est z, et elle varie selon x et y, 
les coordonnées de votre carte. Donc le sol même de la nature est, en gros, 
une surface du type z = f(x, y). Évidemment la fonction est excentrique, 
car la nature est capricieuse. Mais on peut toujours, avec des fonctions 
simples, faire des paysages assez ressemblants, comme nous le verrons au 
Paragraphe 5. 

Ce point étant éclairci, il faut expliquer le second : pourquoi les parties 
cachées sont-elles plus faciles à gérer sur de telles surfaces ? 


4. UNE ASTUCE SPECIALE : PARTIES CACHEES 
SUR DE TELLES SURFACES 





Pour ne pas tracer les parties cachées de ce genre de surface, nous 
aurons recours à une astuce assez connue, et qui repose plus sur la logique 
que sur les mathématiques, pour une fois. 


colonne XX 


à, 














Figure IX.C 
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Examinons la Figure IX.C. Sur ce schéma, on a représenté, à gauche, 
six courbes extraites d’une surface en forme de cratère. Ces six courbes 
sont parallèles, c’est-à-dire qu’elles sont tracées à x constant. La surface est 
dessinée en isométrique. 


Ces courbes sont tracées dans l’ordre de la flèche, c’est-à-dire dans 
l’ordre où x décroît. C’est essentiel. Par exemple, pour tracer la première 
courbe, on aura fait varier y avec x = 2, la deuxième avec x = 1,8, la 
troisième x = 1,6, etc. 

Or vous remarquez que la dernière courbe passe un moment derrière les 
autres. Cette partie cachée est représentée en pointillé. Comment faire 
comprendre à l’ordinateur, lorsqu'il arrive au point a sur cette courbe, 
qu’il ne doit rien tracer par là ? 

C’est ici que l’astuce joue. Appelons XX et YY les coordonnées 
(projetées) du point a. On a redessiné à droite la colonne XX. N'oubliez 
pas en effet que votre écran est formé de 640 colonnes, et que tout point se 
trouve nécessairement sur l’une d’elles. 


Nous voyons que sur cette colonne il y a déjà des points des autres 
courbes, les cinq dernières (numérotées de 1 à 5). Parmi ces points déjà 
tracés sur la colonne, il en est un qui est plus haut que les autres (celui de la 
courbe 4), d’ordonnée sup, et un plus bas que les autres, d’ordonnée inf. 
Que voit-on pour YY ? YY est compris entre inf et sup. C’est pour cela que 
le point a est invisible. S’il était plus haut que tous les autres, ou plus bas, il 
serait visible. 


Récapitulons ce qui s’est passé sur cette colonne depuis le début du tracé 
de la surface. Avant que l’on trace la courbe 1, il n’y avait jamais eu aucun 
point sur la colonne. Puis, la courbe 1 est tracée : appelons Y, l’ordonnée 
du point qui se trouve sur cette colonne. On pose alors sup = inf = Y:: 
l'unique point est alors le plus haut et le plus bas à la fois. Puis on trace la 
courbe 2. Le nouveau point est au-dessus du précédent : Y, est supérieur à 
sup. Donc le point est visible ; on pose, après l’avoir dessiné, sup = Y;, 
puisque c’est lui le point le plus haut. Même chose après le tracé de la 
troisième courbe, puis de la quatrième. Chaque fois, le point est au-dessus 
des autres. À ce moment, sup = Y,etinf = Y, (n’a pas changé). Puis, sur la 
cinquième courbe, on arrive au point a. Et là Ys est compris entre inf et 
sup : pas de tracé, et inf et sup ne changent pas. C.Q.F.D. 

Cette méthode peut paraître un peu abracadabrante, mais elle marche 
très bien. Pour quelle raison profonde ? En fait, tout vient de ce que j'ai 
déjà dit sur les courbes z = f(x, y). Les colonnes de l’écran sont parallèles à 
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l’axe Oz. Par conséquent, en aucun cas une des courbes tracées sur la 
surface ne peut couper deux fois une même colonne : dans chaque colonne, 
il y a au plus un point de chaque courbe, jamais deux. Et c’est cela qui fait 
que le “truc marche”. C’est aussi la raison pour laquelle il ne saurait 
marcher pour une surface quelconque, ni pour la même surface si l’axe Oz 
n’était pas vertical. À présent vous savez, en plus, pourquoi mes axes Oz 
sont toujours verticaux. Cela donne parfois des facilités irremplaçables… 
outre que c’est conforme à la logique ! 


Notez qu’une autre chose est absolument nécessaire pour le bon 
fonctionnement de cette astuce, c’est le tracé avec x décroissant, 
c’est-à-dire avec des courbes qui semblent de plus en plus s'éloigner. Si 
vous refaites le même raisonnement dans le sens inverse, vous verrez 
qu’alors c’eût été la courbe 3 qui eût été amputée, et la courbe 5 serait 
complète. 


Naturellement, cette astuce, il faut la répéter pour toutes les colonnes 
sans aucune exception. C’est pourquoi les valeurs inf et sup sont 
conservées dans deux matrices de 640 valeurs. 


D'autre part (il faut une contrepartie à tout), l’astuce a un côté très 
ennuyeux. Prenons un exemple. Le programme vient de placer un point en 
XXO0 et Y YO, avec par exemple XX0 = 250. Après calcul, le point suivant 
sur la courbe est en XX, YY, avec par exemple XX = 245. En temps 
normal, il suffit de faire DRAW XX, YY, et tout est dit : un petit segment 
est tracé entre les deux points. Mais ici, c’est plus compliqué. Car non 
seulement il faut vérifier que les deux points sont visibles, en comparant 
d’une part YYO avec inf(250) et sup(250), et d’autre part YY avec 
inf (245) et sup (245), mais il faut faire plus encore, car il y a cinq colonnes 
entre XX et XXO0: cinq colonnes que le segment traverse, et pour 
lesquelles il faut impérativement comparer toutes les valeurs intermé- 
diaires XXi et Y Yi situées sur le segment (avec XXï entier, variant de XXO0 
et XX), ce pour bien marquer l'intersection de la courbe et de ces 
colonnes. Sinon, supposez qu’au moment du tracé de la courbe suivante, 
on obtienne XX = 248 un moment, avec YY supérieur à tous les autres 
points déjà tracés sur la colonne 248, mais inférieur à l’ordonnée du 
segment en question situé sur la colonne 248. Si l’ordonnée de ce point, qui 
vaut d’ailleurs Y YO + (YY — Y YO) - (XXi — XX0)/(XX — XX0), n’a pas 
été enregistrée sur cette colonne, le point de la courbe suivante situé sur 
cette colonne sera tracé, même s’il n’aurait pas dû. 
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FROSRAMME Ii. 1 








=== SURFACES EN 3D 
= Entree des donnees 














MÜCE 1:E0RDER 1:INK 6,1: 1:24:FEH 1 
IHPUT "Valeur minimale de x "ixmin: PRINT 

INPUT "Valeur maximale de x "ixmax:PRINT 

INPUT "Valeur minimale de 5 "isgmin: PRINT 

INFUT "Waleur maximale de # "“ismax:PRINT 

IHFUT "Pas d'incrementation finesse) ":h:PRINT 
INPUT "Hombre de courbes Par cote “in:nen-1:PRINT 
GA IHPUT "Facteur d'echelle";ie:PRINT 

14 FRIHT'Youlez-vous voir tracer les 3xes CO/H37" 
24 MHILE IHK 1 AND IHKEY( 46 3=-1 : MEND 

MODE Z:1 &:ERCER G:IHK 1:24:FEH 1 































F7'LOCATE 1,23: 





24,35: CRAUR 12,2 :PLOT 24,35 :DRANR 8 


5: CRAUR -12,2:FLOT 613,3S:DRAUR -8,7: 







=== Preparation 


==szzzszss=ezsezszz [race à x constant 
£ : ax 2/1 
THEN xi=x ELSE K sex RES max ) 


x TO smin STEF h 

THEH y1=4 ELSE 11=e#s/AESC ss max) 
A:GOSUE 9359 

THEH GOSUE 8 











== PreParation (bis) 


Trace a 4 constant 


Calcul de z:Points caches 





IF JS AND YY£=S THEH f9=@:RETURH 


Fcutine de tracase d'un sement 
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IF “Yi£=l THEN infé 
IF f21=1 THEH DER 
1 fa1=1 
+19 HEXT 

24 RETURN 





“alidite de l'abscisse 











Sauver l'ecran sur cassette 


LOCATE 1.1 
PRIHT CHR 7) 





3 SAVE 

A PRINT CHR&C F2 

A HHILE INKEYT$="": MHEND 
MODE 1:INK @,1:BORDER 1:PEH 1 
ENC: 














Les grands dessins valant mieux que les longs discours, je vous propose 
de supprimer les lignes correspondantes dans le Programme IX.1 
(lignes 800 et suivantes) en les remplaçant par un simple DRAW XX, YY 
pour voir le désastre, si d'aventure vous n’étiez pas convaincu. 

À propos de ce programme, il me reste encore quelques petites 
explications à donner, en vrac. 

La finesse h désigne la distance entre deux points de calcul sur une même 
courbe. A choisir inférieur à 0,1, de préférence. n est le nombre de courbes 
tracées sur chaque côté du rectangle de base. Ce rectangle est celui limité 
par les droites x = Xmin, X = Xmax> Ÿ = Ymin> Ÿ = Ymax dans le plan xOy. On le 
distingue en général très bien après le tracé. Ce rectangle est nécessaire : la 
plupart de ces surfaces sont infinies (sauf fonctions farfelues), on ne saurait 
donc les tracer tout entières. 

Le programme fait en sorte que le rectangle tienne entièrement sur 
l'écran. Si vous voulez l’agrandir ou le diminuer, le facteur d’échelle e est 
là pour cela. Supérieur à 1, il agrandit, inférieur à 1, il diminue. Au début, 
rentrez e = 1. 

Vous avez le choix entre la surface avec les trois axes du repère, ou sans. 
Si vous choisissez sans, appuyez fortement sur la touche n. 

Les calculs sont faits en radians. Rien ne vous empêche d’en décider 
autrement, en changeant la ligne 210. 

Pour chaque colonne, inf et sup sont initialisés à 400 et 0, respecti- 
vement. Ainsi le premier point d’une colonne sera toujours tracé, sans 
nécessiter un traitement spécial. 
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La finesse est donnée positive, mais comme on trace avec x et y 
décroissants, il faut changer le signe de h (ligne 240). 

On exécute d’abord le tracé à x constant, puis à y constant. Précisons 
que les lignes 320 et 520 servent à faire tenir le rectangle sur l’écran. Les 
coordonnées projetées sont calculées en isométrique, et multipliées par 
180. L'origine n’est pas placée en 320, 200, car il faudrait alors initialiser 
sup à — 200, ce qui est assez long. On ne considère que la partie entière de 
XX. 

La fonction f(x, y) doit être placée en 710. Des exemples seront donnés 
au paragraphe suivant. 

Deux flags sont utilisés. Ils sont destinés à savoir si l’on est au début 
d’une courbe (fg), ou au début d’une partie visible, après une partie cachée 
(fg1). Dans ce cas, il ne faut pas faire de DRAW. 

Enfin, lorsque la surface est terminée, le programme fait un bip sonore. 
Vous avez alors le choix entre vous arrêter (touche f comme fin), ou faire 
enregistrer la courbe sur cassette ou disquette, sous forme d’enregistre- 
ment d’écran: appuyez alors sur la barre, non sans avoir vérifié que les 
touches REC et PLAY sont enfoncées, car aucun message ne sera affiché 
(il abîmerait la surface). Lorsque l’enregistrement est fini, nouveau bip. 
Appuyez sur n’importe quelle touche lorsque vous serez lassé de l’admirer. 
Pour récupérer votre surface, ensuite, tapez LOAD “Surface”, B,49152. 

Pour que vous puissiez tester ce programme sans vous casser la tête, 
nous allons à présent voir quelques exemples très utiles. 


5. EXEMPLES ET UTILISATION 





Il est rarement aisé de trouver la fonction mathématique adaptée 
exactement au paysage que l’on veut faire. En fait, pour peu que ce 
paysage soit un peu compliqué, c’est impossible sans un minimum de 
méthode. 

On peut pourtant aboutir assez rapidement au résultat cherché. Il suffit 
pour cela d’utiliser la méthode des superpositions. Si par exemple vous 
souhaitez faire deux montagnes côte à côte, ne cherchez pas une fonction 
mathématique géniale qui vous donnera la bonne surface. Allez plutôt 
prendre dans les exemples suivants ceux qui représentent des montagnes et 
additionnez-en deux. En effet, en additionnant deux fonctions qui 
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représentent chacune une montagne, ou n’importe quoi, vous avez toutes 
les chances de voir apparaître deux montagnes sur la surface. 

Quelques précautions sont toutefois nécessaires. La première est 
simple : les fonctions utilisées doivent être nulles à l’infini, c’est-à-dire que 
z doit devenir très faible quand on s'éloigne du centre de la fonction, 
centre qui sera donné dans les exemples. C’est une condition importante : 
si elle n’est pas réalisée, z risque de devenir trop grand à l’infini, d’où de 
graves problèmes. Cette condition est automatiquement réalisée pour les 
fonctions qui suivent, sauf pour Déclivité, où elle est impossible, l’un des 
niveaux restant forcément plus haut que l’autre. 

Seconde précaution importante: s’assurer que la superposition est 
correcte. En effet, si l’on additionne deux fonctions dont les centres sont 
très proches, on risque d’avoir un “méli-mélo” (par exemple une grosse 
montagne au lieu de deux) ; il faut pour cela vérifier jusqu'où s’étend le 
domaine de la fonction (valeurs de x et y pour lesquelles z n’est pas faible). 
Si les deux domaines se superposent trop, on obtient autre chose. Cela 
peut être intentionnel, d’ailleurs, nous le verrons. 


Voici donc les six fonctions types qui permettent de faire la majorité des 
paysages intéressants. Dans la suite r désigne le r des cylindriques, soit 
sqr ((x — a)? + (y — b}?), où (a, b) est le centre de la fonction. u désigne une 
coordonnée linéaire du type: u=cos(æ) : x+sin(æ) : y+k. Ces six 
fonctions sont illustrées sur la Figure IX.D, où elles sont repérées par leur 
numéro d’ordre. 


1. Colline - Creux 
Fonction: z = A : EXP (- r//k?) 


A S'il est positif, c’est la hauteur de la colline, sinon la profondeur du 
creux. 


k Paramètre de domaine. z devient petit (inférieur à A/10) lorsque 
r (distance à l’axe du sommet) est supérieur à 1,52 : K. 


2. Pic - Trou 


Fonction: z= A : exp (2) 
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A Comme ci-dessus. 


k Positif obligatoirement. Règle la pente du pic: plus k est 
important, plus le pic est évasé (mou, et non pointu). 


m Paramètre de domaine. z devient faible (idem), lorsque r est 
supérieur à m + 2,3 : k (m peut être négatif). 


3. Bloc rond 
Fonction: z = A : (0,5 + ATN (k : (m — r))/PI). 


A Est pratiquement la hauteur du bloc. 
k Plus k est important, plus les côtés du bloc sont inclinés. 
m Est le rayon de la partie haute du bloc (exactement à mi-hauteur). 


Domaine : Si k est beaucoup plus grand que m (au moins dix fois), le 
domaine s’arrête à quelques fractions de m du bloc. Ainsi, si 
k=32 : m, à une distance de 2m du centre du bloc, z ne vaut plus que 
A/100. 


4. Plouf 


Ainsi nommée car elle évoque l’eau quand on y jette une pierre. Mais 
scientifiquement, il s’agit d’un sinus cardinal. 


Fonction: Z = A : sin (rk)/rk (en radians). 


À Hauteur du pic central. 


k Règle l’élongation des ondulations (qui sont en nombre infini, mais 
qui sont invisibles assez vite) : plus k est petit, plus les rides sont 
serrées. Cette surface rappelle les ondulations du sinus qui 
l’engendre. 


Précaution : S’arranger (avec les bornes) pour que r ne soit jamais nul, 
sinon division by zero. 


Domaine : Invisible quand r dépasse quelques 10/k. 
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5. Falaise - Déclivité 
Fonction : z = A : ATN (u/k)/PI (en radians). 


A Est la différence de hauteur entre les deux niveaux. 
La droite u = 0 est l’endroit où se trouve la déclivité. 


Paramètre de domaine: plus k est important, plus la pente est 
faible. Ainsi la moitié de la hauteur du niveau supérieur est atteinte 
quand on s'éloigne d’une distance k de la droite u = 0. 


Conseil : Si vous souhaitez interchanger le haut et le bas, changez le 
signe de u, ou de k. 


6. Faille 
Fonction: z=-—A: EXP (er = = D) 


A,m,k Même sens que pour le pic. 


u Même sens que ci-dessus. 


Les figures de ce chapitre, et celle de l'introduction, ont été faites en 
additionnant de telles fonctions. 

Ainsi pour la Figure IX.A, si l’on a, en distinguant les centres, en O: 
ro=sqr(x?+y*), ra=sqr(x—10)+(y—3)) en A(10,3), et ainsi de 
suite, rb, rc. en B(8,5), en C(— 1,7), D(— 13,5), E(7,—9),F(12,—1), 
avec la fonction suivante : 

A ri 


z= {9 ExP(TE) + 12 | EXP (=) -s : EXP(-r0) 


| ie) 
+20 Exp (Ce e 


HAS ExP(—) LR Exp(=E+10) 


+10: Exp(Ce) + 
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2 
Te 


8 











ss = 
]-7-ExP| Æ)+15-ExP | T)-2}115 


+15- EXP 2 - 3 


Cette fonction est compliquée, mais elle se comprend très bien si l’on 
regarde seulement autour de chacun des points cités ci-dessus. Par 
exemple, en C, tous les termes de la fonction sont faibles, sauf 


ARS ' 
10 : exp F5, que l’on reconnaît comme une colline assez haute 


(A = 10) et peu évasée (k=72, ce qui est faible) ; on la reconnaît sur la 
figure au centre légèrement à droite. 


En F, seul le terme 15 : EXP me) est important. On reconnaît un 
pic, assez haut (A = 15), peu évasé (k = sqr (2)), et surtout pointu, car de 
, ; : A 
domaine peu important : m = 0, d’où z = 10 quand: 


r=2,3 : sqr (2) =3,3. 


On reconnaît ce pic à l’extrême gauche de la figure. 
On peut ainsi identifier tous les pics de la figure. 
C’est plus simple sur la Figure IX.B, de fonction : 


sin (7: PI/2) 


2= 14. | 
r 


5 - EXP (- 7 | (r est le ro ci-dessus). 


C’est simplement la différence entre deux fonctions : un plouf que l’on 
reconnaît bien, et un frou qui se voit tout en haut et au centre de ce plouf. 

Le principe est plus général; pour faire un cratère en haut d’une 
montagne (volcan), il faut additionner un creux ou un trou à cette 
montagne, avec le même r. C’est ce qui a été fait sur la Figure IX.A aussi, 
aux points O et F. 

Ainsi, tous ces effets de compensation ou d’additionnement peuvent 
engendrer des paysages très variés sans trop de mal. Précisons que les 
Figures IX.A et IX.B ont été tracées en environ deux heures avec 
respectivement x et y variant entre — 15 et 15, entre —9 et 9 ; des pas de 
0,25 et 0,15 ; des échelles de 1,5 et 1 ; enfin 61 et 41 courbes par côté. 

Il ne vous reste plus qu’à essayer et... à vous montrer patient. 
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À 
LES PERSPECTIVES OPTIQUES 


Ce chapitre est là pour clore cet ouvrage sur un champ nouveau d’investigations : 
sur la manière dont un objet est vu, et non sur la nature de l’objet. Il peut, de ce 
fait, s'appliquer à tout ce qui a été vu dans les chapitres précédents. Un réalisme 
plus frappant est toutefois obtenu au prix d’une durée plus importante de calcul 
(comme toujours, et c’est pourquoi l’application de ce système à l'appartement du 
Chapitre VII, qui constituait déjà l’un des sommets de ce livre, pour si modeste 
qu’il fût, ne sera qu’esquissée). 


1. POURQUOI LA PERSPECTIVE OPTIQUE ? 





Si vous avez eu la curiosité de faire un cube sur votre Amstrad, à l’aide 
du programme Polyèdres de révolution, vous avez peut-être été légèrement 
choqué par sa forme, trop parfaite, en quelque sorte: les côtés sont 
strictement parallèles, le fond a la même taille que la face de devant, etc. 

Or, chacun sait que les objets ne nous apparaissent pas ainsi. Les côtés 
d’un cube ne sont pas parallèles, mais fuient vers l’horizon. Qui n’a jamais 
regardé, de la rue, le haut d’un immeuble : il semble moins large que le 
bas. Et une route qui s’enfuit vers l’horizon semble devenir de plus en plus 
étroite. 

Les peintres de la Renaissance se sont mis en réaction par rapport à ceux 
du Moyen Âge, car ils voulaient en effet rendre cette réalité, que nous 
appellerons perspective optique, ou perspective tout court, alors que les 
peintres du Moyen Âge ne le faisaient pratiquement pas. 

Pour cela, ces artistes durent établir les règles complexes de la 
perspective en peinture, basées sur une observation rigoureuse des choses 
vues. Ils arrivèrent ainsi à de remarquables résultats. 

Je vous propose de faire la mêrhe chose. Nous allons réagir par rapport à 
tout ce qui précède, qui n’était pas assez bien représenté. Cela n’est pas 
absolument nécessaire, bien sûr, et les projections classiques que nous 
avons faites jusqu’à présent donnaient, dans l’ensemble, des résultats très 
proches de la réalité. 

Cependant, dans certains cas, la perspective optique sera nécessaire, et 
c’est à ces cas que je pense. 


2. OUI, MAIS COMMENT ? MANIERE APPROCHEE 


Prenons un exemple. Vous faites un jeu où un avion se rapproche de sa 
cible, vous en l’occurrence, je veux dire le joueur. On doit donc voir 
l'avion s’approcher. Seulement, voilà. Si vous avez eu l’idée (bonne, 
malgré tout) d’utiliser le programme Tous polyèdres pour faire votre avion, 
un léger problème va se poser. Comment le faire s'approcher, tout 
d’abord ? Cela, c’est facile à résoudre, comme nous le verrons. Mais de 
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12190] 2p uvjg — (a18uv Puvi8) anbndo 24nsads1od u9 321qO : V'X 24n8u 














toute façon l’avion resterait de la même taille, ce qui est très ennuyeux, car 
lorsqu'un objet se rapproche, on a l’impression de le voir grossir. 

Heureusement, dans un tel cas, la solution est simple. Il suffit de le 
grossir artificiellement (et au hasard, de surcroît). L'effet n’est pas parfait, 
mais peut suffire. 

On peut aussi procéder par approximation pour d’autres choses. Par 
exemple pour une route s’éloignant vers l'infini. Il faut alors espérer que le 
terrain est bien plat et la route bien droite, sinon tout se complique... 

Par contre, pour les pièces, cela devient dommage. Combien de ces 
programmes de jeux vendus dans le commerce, excellents, mais péchant 
par une forme trop stéréotypée des pièces où le joueur se déplace... Et 
pourtant, ce n’est pas si difficile. 


3. OUI, MAIS COMMENT ? (SUITE) MANIERE SCIENTIFIQUE 








On se flatte comme on peut mais il est vrai, après tout, que c’est une 
démarche scientifique que nous allons adopter pour la résolution de ce 
problème. 

Nous voyons comme les appareils photo, ou plutôt c’est le contraire. Les 
photos, elles, établissent automatiquement les perspectives. 

Or, comment est fait un appareil photo ? En gros, il y a un objectif, et 
une plaque photographique derrière. Pour l’œil c’est la même chose. Dans 
les deux cas, l’image obtenue est inversée, comme on sait. Pour l’appareil, 
des lentilles auxiliaires, et pour l’œil, le cerveau, rétablissent l’image dans 
son sens normal. L’effet obtenu est le même que si la pellicule se trouvait 
devant l’objectif, comme nous le verrons. 

L'effet de perspective est dû à une cause profonde qui n’est pas très 
difficile à comprendre. 

La projection orthogonale, que nous avons utilisée jusqu’à présent, 
envoyait vers l’écran des rayons parallèles. La conséquence était simple : 
avec un tel système, une sphère de rayon dix centimètres aurait été 
représentée sur l'écran par un cercle de rayon dix centimètres, la 
projection conservant les dimensions parallèles à l’écran. 

À moins d’avoir une très grande plaque photographique, je vois mal 
comment, avec le même système, vous pourriez photographier une telle 
sphère, pourtant bien plus petite qu’un simple ballon de football. Quant au 
mont Blanc, n’en parlons pas! 


- 204 - 


Conclusion: votre appareil photo ne voit pas par une projection 
orthogonale. Cela, on le savait déjà. Comment fait-il alors ? C’est assez 
simple, en fait. Il existe dans l’appareil un point que l’on appelle focal, et 
que nous appellerons point O dans la suite. Au lieu que ce soit les rayons 
lumineux perpendiculaires à l’écran qui impressionnent la pellicule, ce sont 
ceux qui passent par O (n'oubliez pas qu’un objet envoie des rayons 
lumineux dans toutes les directions, sinon on ne pourrait pas le voir de 
partout). 

Chaque rayon lumineux issu de l’objet et passant par O impressionne la 
pellicule derrière. En fait, pour nous, il s’agit essentiellement de trouver 
l'intersection du “rayon lumineux”, c’est-à-dire en fait de la droite joignant 
O à l’objet vu, avec l’écran. Ce dernier, pour éviter une inversion de 
l’image, se trouve devant le point O, et non derrière. Voyez ainsi la 
Figure X.B. On y a imaginé que l’observateur (dont l’œil se trouve en O) 
se déplaçait dans un champ de météorites. Trois d’entre elles ont été 
représentées : M1, M;, M3. Seules les deux dernières ont une image sur 
l’écran, car la droite O — M, ne touche pas l’écran. C’est là en effet une 
réalité : l'écran est borné, comme une pellicule photographique ou votre 
rétine. Vous ne pouvez voir à la fois tout ce qui vous entoure, et l’appareil 
photo ne peut prendre tout le paysage d’un coup. 








Figure X.B 
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Il en est de même ici. D’une façon générale, ces dispositifs optiques sont 
caractérisés par un angle qui définit la largeur de leur champ de vision. Cet 
angle peut être plus ou moins important (de 0 à 180° en hauteur, et de 0 à 
360° horizontalement). L’œil humain ayant un champ de vision pas très 
large, on peut ainsi obtenir des effets amusants en utilisant sur un appareil 
photo un objectif “grand angle” (fish-eye). Un basset ainsi photographié 
semble avoir une tête énorme et de toutes petites pattes. Il en est de même 
sur la Figure X.A, où le même polyèdre de forme oblongue (il ressemble à 
un crayon à papier) a été représenté selon un grand angle (environ 70°). 


Cette figure a été obtenue à l’aide du Programme X.1, destiné à être 
amalgamé au programme Tous polyèdres (voir Chapitre VI). 


FROGRAMPIE. SX. 1 



















iiknct .Mi+(Déks14#s2-etact. 6, 1 12#nét, 154 





>-1.125 GOTO 1544 
#1#115/21 
#1#115/21 









Points lointains 
RETURN ELSE RETURH 







AND Y1=@ THEH IF 21 
L'SDRCKTKRIEYTEY 10 


RETURN 
a=INKEYCGD:IF a<2-1 THEN GOSUE 1%4@:D0=0-b:GO0OTO 649 

3=INKEY(Z22:IF a<2>-1 THEN G 3 1944: D=C+b: GOT 649 

PRINT:PRINT"_ “"4+CHRSC 248 4" où “+CHRSC 241)" pour faire avancer où 
uler ""le Polsedre," 

5 PRINT:PRINT"_ "+ -HRE 244)+" cui "+CHR$E 2412" Pour faire avancer Ou 
rec üler"” le Polyedre 





















Ce programme permet de tracer les polyèdres en perspective optique. 
Le dispositif est celui de la Figure X.B. L'écran est placé à une distance de 
115 par rapport à O, ce qui donne un grand angle. En effet, cette distance 
de 115, agrandie ou diminuée, diminue ou agrandit l’angle de visée. 

Le point O se trouve du même côté de l’écran que vous, ou plutôt que 
votre œil. Ainsi, vous aurez effectivement l'impression que votre œil se 
trouve en ©. La position relative du polyèdre par rapport à l’écran est, 
comme pour les météores, totalement indifférente : il peut être devant 
comme M;, ou derrière comme M;. Souvenez-vous qu'il en était de même 
lors des projections classiques. L’écran est en fait un plan de vision fictif, le 
seul vrai étant celui de la rétine, ou la pellicule. 

Le repère X1, Y1, Z. est le même que d’habitude, à un détail près: le 
nombre D, qui est la distance entre O et le polyèdre. D en effet ne saurait 
être nul : on ne verrait rien. D’où une légère différence dans le calcul de Z; 
(voir lignes 1210 à 1230). 


Pour qu’un objet soit visible, il faut que les coordonnées projetées XX et 
YY ne soient pas trop grandes (pour ne pas sortir de l’écran), mais aussi il 
faut que Z, soit négatif. Dans le cas contraire, l’objet est de l’autre côté de 
O, derrière vous. Dans ce cas, le point est placé très loin, sur un cercle de 
rayon 30000 (XX et YY ne doivent pas dépasser 32760). S'il y a un trait à 
tracer, il sortira de l’écran, vers ce point à l'infini, ou presque (lignes 1500 
et suivantes). Cela se fait également si Z,; est négatif, mais faible en valeur 
absolue. Cela se comprend quand on voit le calcul de XX et YY 
(lignes 1530 et 1540): si Z; est trop proche de zéro, XX et YY vont 
dépasser la valeur fatidique de 32760, et il y aura une erreur. D’où ce 
nombre de 1,125, égal (à peu près) à 320 : 115/32760. X,; et Y, étant 
supposés ne pas dépasser la valeur 320. 

Mais d’où vient donc cette formule ? 

C’est assez simple. On a un point M de coordonnées (X:, Y:,Z1). On 
cherche l'intersection de la droite passant par O (0,0,0) et du plan 
d’équation Z,=—115. Ce point d'intersection m, de coordonnées 
(XX, YY,ZZ), est sur le plan: donc ZZ = 115. D'autre part, il est sur la 
droite OM. Donc (voir Chapitre II, Équation paramétrique d’une droite), il 
existe un certain k tel que XX=X, k, YY=Y, k,ZZ=Z;:k.Vula 
valeur de ZZ, k = — 115/Z;, et voilà XX et YY. C’est tout simple. Il suffit 
de regarder les éléments dont on dispose. 

Un peu plus compliqué : comment savoir si une face est cachée ou non ? 
Là encore, réfléchissons. La face est cachée si le point O se trouve du 
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même côté de son plan que le reste du polyèdre. Or l’équation du plan 
d’une face qui passe par le point (46,41,42), et de vecteur normal 
(no, 1, M), est: 


(x — ao) : no+ (y — a) : m+(2—-@) : n=0 


c'est-à-dire la nullité du produit scalaire MA par le vecteur normal. 
Lorsque ce même produit scalaire est positif, le point est à l’extérieur de la 
face, vu la manière dont le vecteur normal a été choisi. 

D'autre part, le point O a pour coordonnées dans le repère x, y, z 
D : ©: 52, D : 51 : 52, D : ©), car il se trouve sur l’axe OZ, (dirigé par le 
vecteur normal à l’écran habituel (c1 : 52, 51 : 52, C2)), à la distance D. 

Dès lors, il suffit de remplacer x, y, z par ces coordonnées dans le 
produit scalaire précédent, pour savoir si O se trouve du bon côté, et donc 
si la face est visible ou non. Tout cela pour des polyèdres convexes, cela va 
sans dire. On retrouve tout ce calcul dans la ligne 625, modifiée comme il 
faut. 


À propos de cette distance D, sachez encore qu’elle est initialisée à 200 
(moyen) (ligne 550), mais que vous pouvez la faire augmenter ou diminuer 
avec les touches du curseur, pour donner l'illusion de vous rapprocher ou 
de vous éloigner. 

Il ne vous reste plus qu’à essayer l’ultime programme de ce livre. Si vous 
trouvez la déformation un peu excessive (elle l’est, mais c’est pour qu’on la 
voie bien), augmentez simplement la valeur 115, et changez en même 
temps le 1,125 de la ligne 1240. Il faut mettre à la place votre nombre, 
multiplié par 320/32760. 


Enfin, si le cœur vous en dit, rien ne vous empêche d’adapter ce type de 
programme sur des programmes plus complexes, comme ceux du 
Chapitre IX, ou encore le VII.1. Pour ce dernier, je ne l’ai pas fait, 
quoiqu'on puisse certainement obtenir des effets très intéressants (à 
condition de pouvoir aussi se déplacer vers la droite ou la gauche, et vers le 
haut ou le bas, ce qui n’est pas trop compliqué encore). En effet, le 
Programme VII.1 seul est assez lent, et cela ne pourrait que le ralentir un 
peu plus. D’autre part, la gestion des parties cachées est plus compliquée, 
car les verticales ne sont plus parallèles : on se retrouve alors, en fait, 
devant le même problème que pour les polyèdres concaves. J'avais déjà 
indiqué comment le résoudre à ce moment : cela n’a pas du tout changé. 
Simplement les calculs sont un peu plus longs. 
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Donc, là encore, je dois m’arrêter pour des raisons de lenteur. Si vous 
tenez absolument à venir à bout de tels problèmes, passez tout de suite au 
chapitre suivant, le tout dernier. 


— 209 - 


XI 
POUR CONCLURE... 


Afin de ne pas rester sur de mauvaises impressions, je vais développer dans ce 
court chapitre final quelques considérations générales comme au Chapitre VII, 
qui, je le souhaite, vous permettront peut-être d’ajouter à votre palette 
tridimensionnelle quelques éléments qui la rendront plus rapide, plus performante, 
ou simplement plus esthétique. 

En effet, je rappelle que tous les programmes de ce livre ne sont pas réellement 
destinés à être utilisés tels quels, mais plutôt à servir d'exemples, pour que vous 
puissiez plus aisément construire les VOTRES, le but global de cet ouvrage n'étant 
pas de limiter votre champ d’investigations, bien au contraire. 


1. OPTIMISATION DES ANIMATIONS 





L’accélération des effets d’animation, comme par exemple la rotation 
des objets, que nous avons vue, n’est pas réellement possible en BASIC. 
En effet, j'ignore si vous l’avez noté, mais l’ordre DRAW en particulier, 
que nous n'avons pratiquement cessé d'utiliser, est d’exécution fort 
longue, comparativement aux ordres de calculs. 

Toutefois, certains effets intéressants peuvent être obtenus sans trop de 
mal. Par exemple, lors du tracé d’un polyèdre, on peut obtenir une sorte de 
“fondu enchaîné”, en n’effaçant pas l’écran, mais en pratiquant ainsi : face 
par face, on commence par effacer l’ancienne face (en retraçant dessus en 
noir), puis l’on trace la nouvelle. Ainsi le polyèdre ne semble pas quitter 
l'écran, mais à la fin du tracé sa position a changé. 

Autre possibilité : au lieu, par exemple, de faire une rotation de dix 
degrés, faites dix rotations de un degré à la chaîne. Cela sera plus long 
évidemment, mais l'effet d’animation sera meilleur. Nous verrons 
d’ailleurs au prochain paragraphe comment rendre les calculs plus rapides 
pour de tels effets. 

Encore un exemple. Si vous avez un personnage qui vous représente 
dans un jeu, qui tourne sur lui-même dans un paysage de surface en trois 
dimensions, plutôt que de faire retracer toute la surface faites-lui 
simplement faire un décalage, vers la droite par exemple, chaque colonne 
remplaçant celle qui était à sa droite; la colonne la plus à droite sera 
stockée en mémoire, la plus à gauche viendra de la mémoire. Naturel- 
lement, cela n’est guère possible qu’en langage machine, mais si votre 
programme est en BASIC, rien ne vous empêche de créer une instruction 
supplémentaire à cet effet. 

Naturellement je ne doute pas que bien d’autres effets sont encore 
possibles ; il suffit que vous trouviez ceux qui sont exactement adaptés à 
votre cas. 


2. OPTIMISATION DES CALCULS 


=". .…———_—_—_——————…—…—…—…—…—….…—…—…—.—.————— 


Il existe de nombreuses manières d’optimiser les calculs. La plus 
importante est assez simple, mais exige une attention soutenue; elle 


s 


consiste à utiliser le bon type de variables, et en particulier à toujours 
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définir comme entières les variables qui le sont, et ce, même dans les 
boucles FOR...NEXT. Cela paraît facile, mais en réalité il faut faire très 
attention ; l’erreur classique en la matière consiste à faire: DEFINT a, 
parce que a est entier, mais sans penser que aa ne l’est pas. 

Deuxième optimisation, que j'ai cherché à exploiter au maximum dans 
tous mes programmes: faire le minimum de calculs longs, comme les 
cosinus, sinus et autres tangentes et exponentielles. Ne pas recalculer cent 
fois le sinus de l’angle psi, si cet angle ne change pas. Le calcul de ces 
fonctions est en effet fort long, car basé sur des sommes de séries. Il faut 
donc l’éviter au maximum. 

L'idéal serait également d’éviter les matrices, qui obligent la machine à 
chercher ses données en mémoire. Cela étant en général impossible, on 
peut toutefois éviter des ralentissements dans la recherche de ces données, 
en évitant de surcharger les programmes par des détails inutiles. Ainsi les 
lignes de REM qui peuplent mes programmes et sont fort longues servent 
uniquement à les rendre plus clairs. Mais une fois que vous les avez 
compris, rien ne vous oblige à les conserver, bien au contraire. 

Au passage, je dois toutefois préciser que la présence de nombreux 
GOTO et GOSUB ne ralentit pratiquement pas les programmes. Cela est 
dû à une particularité du BASIC de l’Amstrad, qui remplace à la première 
exécution du programme tous ces ordres par les JUMP et CALL adéquats 
(aux adresses concernées). L’exécution du programme est ainsi plus 
rapide. En contrepartie, les listings sont plus lents. On ne peut pas tout 
avoir. 


3. DES INCONVENIENTS DU BASIC: 
AUTRES LANGAGES UTILISABLES 








Toutefois, ces petits trucs sont bien pauvres (s’il en existait de géniaux, 
je les aurais mis dans mes programmes), et de toute façon on se retrouve 
toujours bloqué par un obstacle fondamental : le BASIC. Ce langage a 
évidemment pour lui l’avantage de sa relative simplicité, mais en 
contrepartie il est fort lent. 

Vous savez certainement qu’il existe de nombreux autres langages de 
programmation, dont un certain nombre sont déjà disponibles sur 
Amstrad. 
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Naturellement, tous ne sont pas adaptés au graphisme en trois 
dimensions. En particulier, il faut exclure les langages de gestion. Par 
contre, sont tout à fait utilisables le Pascal, le Fortran, même à la rigueur le 
Logo... liste non exhaustive évidemment. 

Cependant, il ne faut pas perdre de vue une chose qui est essentielle : le 
microprocesseur, lui, travaille de toute façon en langage machine, quel que 
soit le langage que vous utilisez en programmation. Les langages cités plus 
haut, à commencer par le BASIC, sont dits interprétés, car ils nécessitent 
un interpréteur qui traduit le langage de programmation en langage 
machine. 

Le seul langage non interprété est donc le langage machine lui-même, ou 
assembleur. Ce langage (il n’y a pas de réelle différence entre l’assembleur 
et le langage machine) est assez difficile (surtout sur le Z80, le 
microprocesseur des Amstrad), mais en revanche il est d’une rapidité 
défiant toute concurrence: en moyenne vingt fois plus grande que le 
BASIC. 

Vous avez le choix entre utiliser un compilateur qui traduira vos 
programmes BASIC en langage machine (en vente dans le commerce), ou, 
ce qui est plus riche mais plus dur (encore une fois, on n’a rien sans rien), 
programmer directement en assembleur : les voies qui vous seront ainsi 
offertes sont infinies, à condition d’avoir la force de s’y engager. 

Cependant, même si vous ne parvenez pas à faire de gros programmes 
en assembleur, même de petits peuvent vous servir. Ainsi vous trouverez, 
dans des ouvrages sur le langage machine, comment accélérer le calcul 
d’une racine carrée, par exemple (votre Amstrad calcule bêtement 
exp(log(x)/2)). Vous pourrez faire toutes sortes d’extensions d’instruc- 
tions (j'en ai cité une au Paragraphe 1): je vous laisse le soin de les 
imaginer, car les possibilités de l’assembleur sont telles qu’elles vous 
viendront spontanément à l’esprit. 

Notez en particulier que tout ce qui est graphique est assez facile à 
programmer en assembleur, et immensément plus rapide qu’en BASIC. 


4. ET DANS L'AVENIR ? 


—————————————  ———————————"—"—"—"—"—"—"—"—"——— 
EE 


Ces spéculations sur l’assembleur ne sont pas seulement des vœux pieux 
ou des indications légères. Souvenez-vous en effet que j'ai renoncé à vous 
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donner deux programmes en BASIC: les polyèdres concaves et l’apparte- 
ment vu en perspective optique, pour cause de lenteur ! 

Aussi, si je parviens à les mettre au point, j'espère avoir l’occasion de les 
publier séparément, programmés en assembleur ou en Pascal. 

Enfin, vous aurez peut-être noté des absences d’envergure dans cet 
ouvrage : il s’agit des fractales. En effet, les possibilités offertes par ces 
objets mathématiques encore récents (ils datent de 1970 environ) sont si 
importantes, que je souhaite vivement avoir un jour la possibilité de 
publier un autre livre qui leur serait intégralement consacré. 

En attendant, le présent ouvrage est terminé. S’il vous a permis, ne 
serait-ce qu’une fois, de programmer par vous-même en trois dimensions, 
en vous échappant du cadre rigoureux de mes programmes, alors il aura 
intégralement rempli les buts qu’il s'était fixé. Je le souhaite de tout cœur. 
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7 ANNEXE À 
THEORIE ET PRATIQUE 
RESUMEES DE LA DERIVATION 





J'ai déjà eu l’occasion dans le texte de parler de courbes, de surfaces, et de 
tangentes ou plans tangents. Comment les calculer, comment les utiliser, voilà ce 
qu’explique la théorie de la dérivation (j'ai déjà aussi parlé de dérivées). Cette 
théorie, qui est fondamentale en mathématiques, n’est pas réellement très 
compliquée (elle est enseignée essentiellement en classe de première), mais je l’ai 
mise en annexe, car elle n’est pas absolument nécessaire à la compréhension de la 
majeure partie de cet ouvrage. 


1. NOTION DE TANGENTE A UNE COURBE 





Sur la Figure A.A, en haut, on voit une courbe, et sur cette courbe, on a 
marqué, arbitrairement, un point M. Un peu plus loin sur la courbe, on 
pose un point H que l’on va faire se déplacer imaginairement sur la courbe, 
de sorte qu’il se rapproche petit à petit de M (en suivant la flèche en 
pointillé) ; trois positions du point H ont été marquées, mais j'aurais pu en 
mettre d’autres plus proches de M, si je n’avais craint de rendre la figure 
illisible. Or, pendant que H s’approche de M, observez la droite MH. 
Cette droite se redresse tout doucement. Finalement, lorsque H arrive tout 
près de M, la droite HM est pratiquement confondue avec la droite T 
marquée sur la figure. 

Cette droite porte le nom de tangente à la courbe au point M. On voit 
assez bien en fait ce qu’est une tangente: c’est une droite qui ne fait 
qu’effleurer en quelque sorte la courbe, exactement au point M. 

La tangente à une courbe en un point est distinguée par une double 
flèche de chaque côté du point, comme pour le point A. Pourquoi une 
double flèche, et non une simple ? En observant l’autre côté de la courbe 
par rapport à M, vous remarquerez que si le point H avait approché M en 
arrivant de l’autre côté (par en bas), la droite HM serait quand même 
venue se confondre avec T. 

Cela n’est pas le cas forcément sur tous les points d’une courbe. Ainsi en 
B, voyez que l’on a porté ce qu’on appelle deux demi-tangentes 
(l'expression est claire, je pense). Ces deux demi-tangentes ne sont pas 
parallèles ; on dit que B. est un point anguleux. Ce n’est pas très fréquent, 
mais cela arrive parfois sur certaines fonctions, comme la valeur absolue 
(y = abs (x) est anguleux en zéro). 

Ne confondez pas le point anguleux B avec un point d’inflexion comme 
C. Sur ce dernier, la courbe s’infléchit (d’où son nom) et traverse sa 
tangente (alors qu’en M, la courbe reste en dessous de la tangente), mais la 
tangente n’en est pas moins la même des deux côtés. Les points d’inflexion 
sont beaucoup plus nombreux. 

C’est aussi de cette manière qu’on détermine la convexité d’une courbe. 
Un morceau de courbe est dit convexe si, en tous ses points, la courbe est 
au-dessus de sa tangente (cas du fragment BC), concave si elle est en 
dessous (cas du morceau MAB). On passe du convexe au concave et 
inversement quand on arrive en un point d’inflexion comme C, ou parfois 
en un point anguleux comme B. 


— 218 - 





Figure A.A 
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D'autre part en A la tangente est horizontale (pente zéro). Notez que la 
fonction est alors fréquemment en un maximum ou un minimum de sa 
valeur. 


2. EQUATION D’UNE TANGENTE — DERIVEE 





On sait qu’une droite dans le plan a pour équation type:y=a:x+b;a 
est appelée pente de la droite. C’est la tangente de l’angle qu’elle fait avec 
Ox (voir figure pour T). Dans le cas de T, si l’on connaît a, on peut trouver 
b facilement car l’on suppose connues les coordonnées (u,v) de M. En 
effet T passe par M, son équation est donc: y—v=a:(x-—u) d’où 
b=v—a :u. Reste donc à trouver a. 

Si la courbe est du type y = f(x) (f est une fonction ; on a donc v = f(u)), 
la valeur de a est appelée dérivée de f au point u. C’est une nouvelle 
fonction, que l’on note f (ou encore TL): en effet, la valeur de a 
est variable suivant le point où l’on se place (elle peut même ne pas exister, 
comme en B). On pourra donc trouver la tangente en tout point d’une 
courbe, à condition de trouver la fonction dérivée f. 


3. CALCUL D’UNE DERIVEE 


Toute fonction f est égale à des sommes, produits, ..…., composées (une 
composée est du type f°g(x) = f[g(x)]; par exemple, sin (exp (x)) est la 
composée de sin et exp: sin, exp) de fonctions dites usuelles : puissances 
de x, exponentielles, fonctions trigonométriques, etc. Je vais donc donner 
à présent deux séries de formules : d’une part les dérivées des fonctions 
usuelles, d’autre part les dérivées de f, g, f : g, f+g..., f et g étant deux 
fonctions quelconques. 


DÉRIVÉES DES FONCTIONS USUELLES 
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La dérivée est à droite, la fonction à gauche. 


constante x 1 
a ke 1/x — 1/X 
sin (x) cos (x) cos (x) — sin (x) 
1 
2 + 
tan (x) 1+tan° (x) atn (x) +) 
sqr (x) 1/(2 sqr (x))  exp(x) exp (x) 


log (x) 1/x k:x k 


FORMULES DE DÉRIVATION 


Idem. Les formules sont numérotées. 


(A). ré THE 

@) f* l'AT He cs 

Cl. PE RE ut HE À 

(4)  1/f = ff? 

(5) ra Fes D 
8 g 

(oO): fe ARE RE 


(7) k:f k-f 


Dans toutes ces formules, k est une constante arbitraire. A partir de là, 
on peut trouver toutes les dérivées usuelles. Par exemple, cherchons 
ensemble la dérivée de la fonction F(x) = sin (2 - x+5). On peut écrire 
F=f(g+h),avecf=sin, g(x) =2 : x, h(x) =5 (constante). Cherchons les 
dérivées de ces trois fonctions. Celle de f est f = cos ; celle de g est g' =2 
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(type k : x) ; celle de h est h' = 0. Dès lors, posons G = g + h. On a alors 
G'=g'+h'=2 (formule (1)). Puis F=f(G)=f°G. Donc: 


F'(x)=G'(x) : f°G=2 : cos(2 : x +5). 


On a ainsi trouvé la dérivée de F. En procédant ainsi, on peut trouver 
une nouvelle formule : 


(8) f(k:x+e) k-f'(k:x+e) 


2 Pie ; k 
Ainsi la dérivée de sqr(k : x + €) est GG :10} etc. 

Calculons la dérivée de TAN sans utiliser la formule donnée, mais 
sachant que 








__sin(x) _f > : ji AS 
tan (x) = HG) avec f= sin et g= cos. On a f’ = cos et g’ = — sin. 
On utilise la formule (5): 
1.1 (cos (x) : cos (x) — (— sin (x)) : sin (x 
tan (x) = cos” @) 
_ (cos? (x) + sin? (x)) _ (Hop- 3 
= et) =1+ Le ) 1+tan°(x), 


soit la valeur donnée. Notons aussi que, comme sin? (x) + cos? (x) = 1, 
cette dérivée est aussi égale à 1/cos? (x). 


Calculez de même la dérivée de cotan (x). Vous devez obtenir 


— (1+ cotan? (x)) = 0 


Calculons à présent la dérivée de log (exp (x)) = F(x). On a F=f°g, 


avec f= log [aroù f- «=2) et g=exp (d’où g'=exp; on dit 


que l’exponentielle est à elle-même sa propre dérivée). Donc par la 
formule (6): 
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1 
Ron = 1 


ce qui n’est pas très surprenant car log (exp (x)) = x en fait. 


Calculons la dérivée de £- F(x). On a F=f°g, avec f(x) = 1/x 


[aroùr (x) = — 1?) et g(x) = x* (d’où g’ (x) = k : x“ — 1). Dès lors par (6) : 


, : 1 k-xk=1 fe..." 
F'(x)=Kk : x* ee Ti 


en simplifiant par x* - ! en haut et en bas de la fraction. Cette formule peut 
être obtenue très simplement en utilisant les puissances négatives: 
e 1 , : Na 

= mZ Dès lors, en appliquant le calcul des dérivées usuelles en 
— k, on obtient : 


GTR rte 2h + De LÉ 





soit effectivement F’. 
1 
nb) 


F=n avec H=fog et f=atn, g=sqr. 


Donc F' = ii (formule (4)). Puis 


Dernier exemple : calcul de la dérivée de F = 


1 


H'()=8"@) -f EG)=S- ET “A+sg (x) 


1 
2 sqr(x) : (1+x) 


(pour x positif, sinon sgr (x) n’existe pas). Donc: 


F'(x) = —1/(2 : sqr (x) : (1+x) - atn? (sqr(x))) 
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Démontrez les formules suivantes : 
dérivée de exp (f) = f’ - exp (f) 
dérivée de log (f) = f'/f 
Calculez les dérivées des fonctions suivantes : 
1. F(x) = log (sin (x)) 
2. F(x)=exp(3 : x*+5:x—7+2 : sqr(x)) 
3. F(x) = sin“ (x) 
4. F(x) = cos(x) (2 +3 : log(x — 1)) 


5. F(x)=log(sqr(x)) (en déduire une expression plus simple de cette 
fonction. Montrez qu’elle résulte des formules: sqr(x)=x* avec 


k =>, et log (x*) = k : log(x)). 


Réponse 1: tan (x) 


Réponse 2: (12 x + 5 + 1), 
P (12 x er Go) F (x) 


Réponse 3: 4 - cos (x) : sin? (x) 


Réponse 4: — sin (x) + (2 + 3 : log (x — 1)) + : ES US 


Réponse 5: F’ (x) = = car F (x) = log (x)/2. 


4. DERIVEE PARTIELLE 


Soit F(x,y) une fonction de deux variables x et y. On appelle dérivée 
partielle de F par rapport à x, et l’on note F,, la dérivée de la fonction, 
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obtenue en considérant y comme une constante. Inversement, c’est x qu’on 
considère comme une constante pour le calcul de la dérivée partielle de F 
par rapport à y, K. Par exemple: 


F(x,y)=x+y:sin(x : y) 
Si l’on considère y comme une constante k, on a à dériver la fonction 
G(x)=x+k:sin(k : x). La dérivée de x est 1, celle de sin(k : x) est 
k : cos(k : x), donc: 

G'(x)=1+k:(k: cos(k : x) = 1+ 42: cos(k : x). 
Nous écrirons que EF = 1 + y? : cos(x : y). 


s 


Calculez à présent F7, en remplaçant x cette fois par k. Vous devez 
trouver x : cos (x : y) +sin(x : y). 


9. UTILISATION 





Regardez le bas de la Figure A.A. On y a représenté une surface type 
z=F(x,}y). En un point M, de coordonnées (a, b), il passe en particulier 
deux courbes planes tracées sur la surface : la courbe z = f(x), avec pour 
tout x, f(x) = F(x,b), et la courbe z =g(y), avec g(y) = F(a, y). Ces deux 
courbes sont appelées C,; et C; sur la figure. Ces deux courbes admettent 
une tangente chacune en M. La pente de ces tangentes est f’ (a) pour C;, et 
g'(b) pour C;. Voyez le paragraphe précédent: f’(a)=K{(a,b) et 
g'(b)=F'(a,b). Or, ces deux tangentes définissent un plan qui est appelé 
plan tangent à la surface en M. Vu ce qui a été dit sur les tangentes, il est 
aisé de trouver deux vecteurs dirigeant ce plan. En effet, une droite de 
pente a admet (1,a), comme vecteur directeur. Dès lors le plan tangent à 
la surface en M peut être aisément trouvé : c’est le plan passant par M et 
dirigé par les deux vecteurs (1,0,F;) et (O,1,F,). 

Nous verrons comment tenir compte de tout cela dans l’ Annexe B. C’est 
en effet surtout à la résolution d’équations implicites que les dérivées nous 
serviront, et au tracé de certaines courbes. 
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Je vous recommande donc d’essayer de bien comprendre cette annexe 
avant de passer à la suivante. Si vous trouvez tout cela vraiment trop 
compliqué, ne vous entêtez pas à l'excès: ce n’est pas absolument 
nécessaire. 
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77777 ANNEXEB 
EQUATIONS IMPLICITES 
RESOLUTION PRATIQUE 

D'EQUATIONS 





Les éléments de cette annexe sont déjà utilisés dans certains programmes et 
chapitres de ce livre (notamment Chapitres VII et IX). Mais ils peuvent servir pour 
d'innombrables autres applications que je ne pourrais détailler. 





1. RESOLUTION D’UNE EQUATION IMPLICITE : 
TRACE DE SA COURBE REPRESENTATIVE 


Soit F(x,y)=0 une équation, dite implicite car sa solution n’est pas 
clairement exprimée, comme pour y = f(x). 

A une telle équation correspond une certaine courbe C en général dans 
le plan ; on dit que C est le lieu des points (x, y) satisfaisant à l'équation. 

Admettons que nous souhaitions tracer cette courbe C. Comment faire ? 

Il faut tout d’abord connaître au moins un point de C. Pour trouver ce 
point de départ, il faut poser par exemple y = 0, et résoudre l’équation en x 
ainsi obtenue (voir deuxième partie de cette annexe). S’il n’y a pas de 
solution, on prend une autre valeur de y, jusqu’à ce qu’on finisse par 
trouver un premier point. 

Une fois ce premier point trouvé, on va en chercher d’autres par une 
méthode approximative. Cette méthode est basée sur une remarque qu’il 
est facile de faire sur la Figure A.A : la courbe, au voisinage du point M, 
est pratiquement confondue avec sa tangente T; il est difficile de les 
distinguer, à condition qu’on soit tout près de M, cependant. 

Donnons-nous un nombre h très petit. Au lieu de chercher un point sur 
la courbe, situé à la distance h de M (de coordonnées x, y), nous allons 
prendre un point situé sur la tangente à la courbe en M, à la distance h. Ce 
point M" ainsi obtenu n’est pas exactement sur la courbe, mais il y est 
presque : le tracé n’est donc en fait qu’approximatif, mais si h est assez 
petit, cela sera suffisant. 

Reste à savoir quelle est la pente de la tangente à la courbe, afin de 
trouver les coordonnées de M’. 

On dispose pour cela d’un théorème très important disant que la 
tangente en un point à la courbe a pour vecteur normal le vecteur de 
coordonnées (EF, F). Cela est également vrai pour la surface F (x, y, z) = 0, 
qui a pour vecteur normal (F,,F,,F.). 

Dès lors, un vecteur directeur de cette tangente est, par exemple, 
(F;,—E). On peut donc poser pour coordonnées de M': x+k:F,, 


y—k:E,, avec k À et r=sqr(E? + EF”), pour que la distance entre M 


et M' soit égale à h. Appelant alors à nouveau x et y ces deux nouvelles 
coordonnées, il n’y a plus qu’à recommencer et, de proche en proche, la 
courbe sera trouvée. 
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2. EXEMPLE D'APPLICATION : SURFACE F (x, y ,z) = 0 





Admettons que nous voulions tracer une surface d’équation 
F(x, y, z)=0, et que nous en connaissions les dérivées partielles de F. 
Deux méthodes sont possibles: celle du Chapitre IX, et celle du 
Chapitre VII. 

Celle du Chapitre IX est (comme toujours) la plus simple. Il suffit de 
tracer les courbes à y constant, puis à x constant, ces deux nombres variant 
dans un domaine donné (voir Chapitre IX). Comment tracer de telles 
courbes ? 

S’il s’agit par exemple de courbes à x constant, x valant donc x, 
l'équation F(xo,y,z)=0 est équivalente d’une équation du type 
G(y,z) = 0, équation implicite à deux variables. Il suffit donc de tracer la 
courbe correspondante, en augmentant y et z petit à petit. Ce travail est 
d’autant plus aisé que G,(y,z) =F;(x0,y,z) et idem pour les dérivées 
partielles par rapport à z. On se trouve donc ramené au cas précédent 
d’une simple courbe à équation implicite. 

Pour faire comme au Chapitre VII, c’est-à-dire tracer l’horizon de la 
surface, c’est un peu plus compliqué. 

Dans ce chapitre, j'avais expliqué que le vecteur normal (qui a pour 
coordonnées les trois dérivées partielles) permet de tracer cet horizon, car 
on peut ainsi en trouver l’équation, donnée par un produit scalaire du type 


vo'FE+w'EF,+":EF=0 


vo, etc. étant les coordonnées de la perpendiculaire à l’écran. 

Donc, posons G = v», : F'+... Comme les trois dérivées partielles, G est 
une fonction de (x, y, z). C’est donc aussi l’équation d’une surface 
(différente, en principe). L’horizon est l’intersection de cette surface avec 
F(x, y, z) = 0 (car n’oublions tout de même pas que les points de l’horizon 
sont sur la surface de départ). Cet horizon a donc une double équation: 
F(x, y, z)=0 et G(x, y, z)=0. Cela définit en général une certaine 
courbe (pensez aux droites: si F et G sont des équations de plan, on 
obtient ainsi les équations intrinsèques de leur intersection). 

Cela ne nous dit pas encore comment tracer une telle courbe. 

C’est tout à fait possible, à condition de connaître un point de départ, 
comme d’habitude. Ensuite, que faire? Réponse dans le paragraphe 
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précédent : trouver la tangente en un point M à la courbe, puis chercher 
sur cette tangente un point à la distance h, et recommencer. 


Ainsi, si t est le vecteur tangent à la courbe en M, on posera: 


h't . h:t, h't 
EE ; 


X=x+ VEN £ 2=2+ 
r r 





et avec évidemment b, f1, t les coordonnées de t, et r sa norme: 
r = sqr (6 + ff + 6). 


Reste donc seulement à trouver les coordonnées de t. Réfléchissons un 
peu: t est la direction de la tangente à l’horizon H. Or, cet horizon est 
tracé sur la surface F(x,y,z)=0, comme C, sur S dans le bas de la 
Figure A.A. Sa tangente est donc dans le plan tangent en M à la surface : 
sa direction t est donc perpendiculaire au vecteur normal à la surface en M, 
dont les coordonnées sont (F',F;,F7). De même t est perpendiculaire au 
vecteur normal à G(x,y,z) =0, soit (G;,G;,G). Dès lors, il suffit de 
prendre pour t le produit vectoriel de ces deux vecteurs normaux, et donc: 


b=F,:G:-F) - Gÿ, 


et ainsi de suite. 

On peut ainsi tracer H. Mais c’est plus difficile, car il faut calculer non 
seulement les dérivées partielles de F, mais aussi celles de G. L'avantage 
des polynômes, c’est que l’ordinateur peut le faire sans trop de difficultés, 
seul, d’où la nature du Programme VII.2. Mais rien ne vous empêche de le 
faire vous-même, et de rentrer ces dérivées partielles comme des données, 
en même temps que F. 

Notez d’autre part que si G est l’équation d’un plan, on obtient par la 
même méthode le tracé de l'intersection du plan avec la surface. 


3. RESOLUTION D'EQUATION A UNE SEULE VARIABLE 


a ———————_—…—…—— —…———. — —_—_—_— 


Tout ce que nous avons trouvé au paragraphe précédent est fort 
intéressant, mais inutile si l’on ne trouve pas le point de départ dont nous 
avons parlé plusieurs fois. 
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Pour trouver ce point, on pose y = yo, Z = Zo, deux constantes choisies 
plus ou moins au hasard, et on espère que, en posant f(x) = F (x, yo, 2o), 
l'équation f(x) = 0 admettra au moins une solution (on dit aussi un zéro, ou 
une racine) xo, qui nous donnera le point de départ (sinon, il faut changer 
les deux constantes et recommencer). Cette solution existera si la droite 
Y= Yo: Z = 20, parallèle à Ox, coupe la surface au moins en un point. 

Il s’agit donc de résoudre l’équation f(x) = 0. 

La valeur de x pouvant varier de l’infini négatif à l'infini positif, il faut 
chercher x seulement dans un domaine donné : x compris entre a et b. 

De deux choses l’une : soit vous avez déjà une idée approximative de la 
valeur de x,, et vous pouvez trouver a et b, soit vous ne savez rien. Dans ce 
cas, l’ordinateur peut (parfois) trouver lui-même a et b. 

En effet, en général lorsque f(xo) = 0, f est d’un certain signe avant xo 
(par exemple f est positif quand x est un peu inférieur à xo), et du signe 
opposé (donc négatif dans ce cas), un peu après. 


Inversement, si l’on peut trouver deux nombres a et b tels que f(a) et 
f(b) soient de signes contraires (ce qui se traduit par f(a) : f(b) négatif), 
on est sûr (sauf fonction très bizarre) qu’il a une racine entre a et b. 

Donc, pour trouver a et b quand on ne sait rien, on procède ainsi: on 
appelle k = f(0). Ensuite on teste f(n) et f(— n), en vérifiant pour chacun 
s’ils ont le même signe que K, en faisant varier n de 1 à l'infini. En fait, on 
s’arrête quand on a trouvé un nombre N, tel que k : f(N) soit négatif (on 
pose alors a=N —1, b=N) ou tel que k : f(— N) soit négatif (on pose 
alorsa=-Netb=-N+1). 


Les deux bornes a et b étant trouvées, on procède ainsi: on pose 
_(a+b) 
7 2 
nul (à une approximation donnée près, par exemple 0,1 près), alors xo = c. 
Sinon, si f(c) : f(a) est négatif, on pose b= c, et s’il est positif, on pose 
a = c. On a alors une nouvelle valeur du couple (a, b) et on recommence au 
début de l’algorithme. 


c , le milieu de a et b, et on calcule f(c). Si f(c) est pratiquement 


En principe, la racine est trouvée au bout d’un certain nombre 
d’itérations. 

Notons qu'il existe d’autres façon de calculer c. Par exemple, prendre 
pour c l’intersection de la droite ab avec l’axe des x, soit 


_a=f() a) 
GG) -f@) 


— 231 - 


et bien d’autres encore, qui permettent selon les cas d’aboutir plus vite, ou 
de trouver même des racines difficiles (cas où f s’annule sans changer de 
signe, comme par exemple f(x) =x?), mais au prix d’une plus grande 
complexité. | 

Le détail de ces méthodes sort du cadre de cet ouvrage. De toute façon, 
il n’existe aucune méthode absolument parfaite. Celle que j’ai donnée a un 
avantage important: sa simplicité. Elle vous permettra de trouver vos 


points de départ dans 99 pour 100 des cas, ce qui est, à mon sens, 
amplement suffisant. 


4._ EXEMPLE D'APPLICATION : DESSIN SUR UNE SURFACE 


Soit une surface d’équation F(x, y, z) = 0 que nous appellerons S très 
originalement, et un dessin plan formé d’une succession de points (reliés 
entre eux ou non), obtenus à l’aide du plot baladeur par exemple. Ce 
dessin représente, supposons, le mot “Surface”. Vous désirez reproduire 
ce dessin sur la surface, comme on grave sur une pomme ou un tronc. 
Comment faire ? 

C’est assez simple. Choisissez d’abord un point M, sur la surface, autour 
duquel vous désirez que le dessin soit fait. Puis prenez un point À à 
l’intérieur de la surface (par exemple le centre si S est une sphère ou un 
ellipsoïde). Calculez le vecteur normal N5 à S en M. 

Soit Uo, Vo, Wo Ses coordonnées. Il y correspond deux angles en 
sphériques. Vous pouvez ainsi trouver un repère Mo, Xo, Yo, Zo, dans lequel 
le plan P tangent en M, à S est égal à xo Mo Yo, par une rotation puis une 
translation. Soit (a, b,c) les coordonnées de A dans ce repère, et soit un 
point du dessin. Ce dessin est supposé, dans un premier temps, se trouver 
sur le plan P. Un point de coordonnées (X, Y) du dessin est donc placé en 
(X, Y,O) dans ce repère Ro. A présent cherchons le point (en principe 
unique) qui se trouve à l'intersection de S et de la droite joignant A à M 
(X, Y,O). Ce point P a pour coordonnées X +k(X —a), Y +k(Y —b), 
—k:c, où k est un paramètre inconnu mais qui est tel que 
F(X+k(X—a), Y+k(Y —b), —k:c)=0, ce qui peut encore s’écrire 
f(k) = 0. Il suffit donc, pour trouver P, de résoudre cette équation. Si A a 
été correctement choisi (dans la concavité de la surface en fait), a = 0 et 
b = 1 conviennent comme bornes, car P est alors situé entre A et M. 
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On trouve ainsi P pour tous les M du dessin, et on le relie de la même 
manière ; le dessin se trouve alors reproduit sur la surface S. Victoire ! 

Bien d’autres exemples d’utilisation seraient encore possibles. D’une 
façon générale, tout ce qui fait intervenir des fonctions un peu compliquées 
utilise peu ou prou la résolution d’équations. C’est pourquoi sa maîtrise est 
extrêmement utile. 
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Représenter des polyèdres, des surfaces, voire des objets 
plus complexes en trois dimensions sur l'écran de votre 
ordinateur. Les faire pivoter pour les observer sous tous 
leurs angles. Supprimer les parties qui, dans la réalité, 
seraient dissimulées au regard, afin de rendre l'impression 
de relief encore plus saisissante. Dessiner des lettres ou des 
petites images sur des plans qui semblent inclinés, sur des 
cônes, des sphères ou des cylindres... 

Ce genre de réalisation ne nécessitera jamais plus de 200 à 
300 lignes de BASIC et même souvent beaucoup moins sur 
votre Amstrad. Ces programmes d'une technique très 
particulière seront transposables assez facilement sur d'au- 
tres appareils. 

Ce sont donc ces techniques de programmation que cet 
ouvrage se propose de vous faire découvrir. Les listings 
détaillés des programmes sont accompagnés de nombreuses 
figures et organigrammes. Le lecteur pourra adapter les 
programmes de ce livre au gré de sa fantaisie. 

Laissez-vous donc entraîner au fil des pages, et vous 
parviendrez presque sans vous en apercevoir, à promener 
votre écran comme une caméra dans un labyrinthe 
diabolique, ou alors dans le salon d'une demeure imaginaire 
que l'ordinateur aura reconstitué pour vous | 

Et la vocation de cet ouvrage se trouvera alors pleinement 
satisfaite, s'il vous ouvre des perspectives auxquelles vous 
n'auriez même pas songé, … en trois dimensions bien 
entendu. 
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